返回

PyTorch自定义Transform方法

发布时间:2023-02-04 14:45:38 293

PyTorch自定义Transform方法_预处理

图像增强为例

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()

PyTorch自定义Transform方法_1024程序员节_02

 

特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像
精选文章
thumb 中国研究员首次曝光美国国安局顶级后门—“方程式组织”
thumb 俄乌线上战争,网络攻击弥漫着数字硝烟
thumb 从网络安全角度了解俄罗斯入侵乌克兰的相关事件时间线
下一篇
opencv图像特征融合-seamlessClone 2023-02-04 14:10:41