pytorch中transform的使用

1.ToTensor转换图片格式

transform是一个transform.py文件,里面包含多个类,其中包括ToTensor类,注意ToTensor是一个类,而不是一个方法,所有首先要创建一个对象,然后在用该对象将图片的PIL格式或是numpy格式转化为Tensor格式,代码如下:

from PIL import Image
from torchvision import transforms

img_path = "data/train/ants_image/0013035.jpg"
img_PIL = Image.open(img_path)

tensor_trans = transforms.ToTensor()
tensor_img = tensor_trans(img_PIL)

print(tensor_img)

上面代码是将PIL格式转化为Tensor格式,如果是要numpy格式的图片,除了之前用numpy.array强制将格式转化为numpy格式外,还可通过OpenCV中的cv2.imread函数直接获得numpy格式的图片,代码如下:

import cv2
cv2.imread(img_path)

2.Normalize图片标准化

Normalize类用于将输入的图片进行标准化,用法是创建对象=transform.Normaliz(n维平均值, n维标准差)其中的输入的第一个参数是图片的n维平均值,第二个参数是图片的n维方差,这里的n是指通道数,一般为3通道,即第一个参数是是一个包含三个数的一维数组,第一个数是第一通道下的平均值,第二个数是第二通道的平均值,第三个数是第三通道的平均值。代码如下:

print(img_tensor[0][0][0])
trans_nor = transforms.Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5]
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch transform 方法主要用于对数据进行预处理和数据增强。它通常应用于数据集的加载过程,用于对每个样本进行相同的操作。 一般来说,transform 方法是 torchvision 包的一个函数,它可以被应用于 DataLoader 的数据集。常见的 transform 方法包括 ToTensor、Normalize、Resize、RandomCrop 等。 ToTensor 将 PIL.Image 或 numpy.ndarray 类型的数据转换为 torch.Tensor 类型,并且将数值归一化到 [0, 1] 的范围。 Normalize 则用于对图像进行归一化处理,通过指定均值和标准差来进行标准化操作。 Resize 用于调整图像的大小。 RandomCrop 随机裁剪图像,用于数据增强。 你可以根据需要按照以下的方式进行 transform 方法的使用: ```python import torchvision.transforms as transforms transform = transforms.Compose([ transforms.Resize((224, 224)), transforms.ToTensor(), transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]) ]) dataset = YourDataset(transform=transform) dataloader = DataLoader(dataset, batch_size=32, shuffle=True) ``` 这里的 transform.Compose 可以将多个 transform 操作串联起来,依次对数据进行处理。在上述示例,首先使用 Resize 将图像大小调整为 (224, 224),然后使用 ToTensor 将图像转换为 Tensor 类型,最后使用 Normalize 对图像进行归一化处理。 当然,具体使用哪些 transform 方法及其参数,取决于你的数据集和任务需求。你可以根据实际情况进行选择和组合。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值