本文学习Resize,Compose,RandomCrop
Resize一般是对PIL格式图像进行操作(类似拉长或者拉高),如果是tensor类型就还需要其他参数。
RandomCrop就是随机裁剪。
这三个都可以见代码后半段
from PIL import Image
from torchvision import transforms
from torch.utils.tensorboard import SummaryWriter
writer = SummaryWriter("logs")
img = Image.open("train/ants/5650366_e22b7e1065.jpg")
print(img)
#ToTensor使用
trans_totensor = transforms.ToTensor()
img_tensor = trans_totensor(img)
writer.add_image("SomeAnts",img_tensor)
#Normalize归一化
print(img_tensor[0][0][0])
trans_norm = transforms.Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])
#output[channel] = (input[channel] - mean[channel]) / std[channel]
#mean均值,std标准差
img_norm = trans_norm(img_tensor)
print(img_norm[0][0][0])
writer.add_image("NormalizeSomeAnts",img_norm)
#Resize
print(img.size)
trans_resize = transforms.Resize((512,512))
img_resize = trans_resize(img)
img_resize = trans_totensor(img_resize)
writer.add_image("Resize",img_resize,0)
print(img_resize)
#Compose
trans_resize_2 = transforms.Resize(512)
trans_compose = transforms.Compose([trans_resize_2, trans_totensor])
#compose后面那个参数的输入是前面参数的输出,trans_resize_2输出PIL,trans_totensor是把PIL型转化tensor型
img_resize_2 = trans_compose(img)
writer.add_image("Resize",img_resize,1)
#RandomCrop
trans_random = transforms.RandomCrop(512,512)
trans_compose_2 = transforms.Compose([trans_random, trans_totensor])
for i in range(10):
img_crop = trans_compose_2(img)
writer.add_image("RandomCrop", img_crop, i)
writer.close()