PyTorch自定义Transform方法
发布时间:2023-02-04 14:45:38 293 相关标签:

图像增强为例
from PIL import Image
from torchvision import transforms
from utils import transform_invert
import random
import numpy as np
class Enhance(object):
"""增加椒盐噪声
Args:
x():乘
y (): 加
"""
def __init__(self, x=1, y=0):
self.x = x
self.y = y
def __call__(self, img):
"""
Args:
img (PIL Image): PIL Image
Returns:
PIL Image: PIL image.
"""
img_ = np.array(img).copy()
img_ = img_*self.x + self.y
return Image.fromarray(img_.astype('uint8')).convert('RGB')
if __name__ == '__main__':
# 1.读取图像
img = Image.open(r"./cat.png").convert('RGB')
# 2.确定预处理方式
img_transform = transforms.Compose([
transforms.Grayscale(),
Enhance(x=2, y=22),
transforms.ToTensor() # 转Tensor型变量
])
img_tensor = img_transform(img)
# 4.逆Transform变换
img = transform_invert(img_tensor, img_transform) # input: shape=[c h w]
# 5.进行预处理效果展示
img.show()

文章来源: https://blog.51cto.com/u_15088375/5805511
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报