常见的Transform类

from PIL import Image
from torch.utils.tensorboard import SummaryWriter
from torchvision import transforms

writer = SummaryWriter("logs")
# 读取图片
img = Image.open("image/tx1.jpg")

1.ToTensor()

作用:PIL Image或numpy.ndarray转换为tensor

代码:

trans_totensor = transforms.ToTensor()
img_tensor = trans_totensor(img)
writer.add_image("Totensor", img_tensor)

说明:创建一个对象trans_totensor("img")默认调用的是__call__方法 return F.to_tensor(pic)

2.Normalize()

作用:用平均值和标准差对张量图像进行归一化,不支持PIL格式

代码:

trans_norm = transforms.Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])
img_norm = trans_norm(img_tensor)
writer.add_image('Normalize', img_norm)

公式:

[channel] = (input[channel] - mean[channel]) / std[channel]规划的公式

 (input - 0.5) / 0.5 = 2*input – 1

Input的图片像素值[0,1]

最后result:[-1,1]

3.Resize()

作用:将输入图像调整为给定大小

代码:

trans_resize = transforms.Resize((600, 600))
# img 是PIL类型
img_resize = trans_resize(img)
# PIL  -- tensor
img_resize_norm = trans_totensor(img_resize)
writer.add_image("resize", img_resize_norm)

4.Compose()

trans_resize2 = transforms.Resize(520)
# Compose()参数是一个列表[transfroms参数1,transfroms参数2...]
# PIL-PIL-tensor
trans_compose = transforms.Compose([trans_resize2, trans_totensor])
img_resize2 = trans_compose(img)
writer.add_image("Resize2", img_resize2, 1)

5.RandomCrop()随机切割

trans_random = transforms.RandomCrop((500,1000))
trans_compose2 = transforms.Compose([trans_resize2, trans_totensor])
for i in range(10):
    img_crop = trans_compose2(img)
    writer.add_image("RandomCrop", img_crop, i)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值