torchvision.transforms

译者:@那伊抹微笑、@dawenzi123、@LeeGeong、@liandongze

校对者:@咸鱼

Transforms (变换) 是常见的 image transforms (图像变换) .他们可以使用 Compose 类以链在一起来进行操作.

  1. class torchvision.transforms.Compose(transforms)

将多个变换组合到一起.

参数:transforms (Transform 对象列表) – 要组合的变换列表.

示例:

  1. >>> transforms.Compose([
  2. >>> transforms.CenterCrop(10),
  3. >>> transforms.ToTensor(),
  4. >>> ])

PIL Image 上的变换

  1. class torchvision.transforms.Resize(size, interpolation=2)

调整输入的 PIL Image 尺寸为给定的 size(尺寸).

参数:

  • size (sequence 或 int) – 期望输出的尺寸. 如果 size(尺寸)是一个像 (h, w) 这样的序列, 则 output size(输出尺寸)将于此匹配. 如果 size(尺寸)是一个 int 类型的数字, 图像较小的边缘将被匹配到该数字. 例如, 如果 height > width, 那么图像将会被重新缩放到 (size * height / width, size). 即按照size/width的比值缩放
  • interpolation (int, 可选) – 期望的插值. 默认是 PIL.Image.BILINEAR
  1. class torchvision.transforms.Scale(*args, **kwargs)

Note: 为了支持 Resize, 该变换已经过时了.

  1. class torchvision.transforms.CenterCrop(size)

在中心裁剪指定的 PIL Image.

参数:size (sequence 或 int) – 期望裁剪的输出尺寸. 如果 size(尺寸)是 int 类型的整数, 而不是像 (h, w) 这样类型的序列, 裁剪出来的图像是 (size, size) 这样的正方形的.

  1. class torchvision.transforms.RandomCrop(size, padding=0)

在一个随机位置裁剪指定的 PIL Image.

参数:

  • size (sequence 或 int) – 期望输出的裁剪尺寸. 如果 size(尺寸)是 int 类型的整数, 而不是像 (h, w) 这样类型的序列, 裁剪出来的图像是 (size, size) 这样的正方形的.
  • padding (int 或 sequence, 可选) – 图像的每个边框上的可选填充. 缺省值是 0, 即没有填充. 如果提供长度为 4 的序列, 则分别用于填充左侧, 顶部, 右侧, 底部边界.
  1. class torchvision.transforms.RandomHorizontalFlip

以概率0.5随机水平翻转图像

  1. class torchvision.transforms.RandomVerticalFlip

以概率0.5随机垂直翻转图像.

  1. class torchvision.transforms.RandomResizedCrop(size, scale=(0.08, 1.0), ratio=(0.75, 1.3333333333333333), interpolation=2)

将给定的 PIL 图像裁剪为随机大小和纵横比例.

原始高宽比的随机大小(默认: 0.08 到 1.0)和随机宽高比(默认: 3/4 到 4/3)的裁剪. 该裁剪最终会被调整为指定的尺寸.

该操作普遍用于训练 Inception networks.

参数:

  • size – 每条边的期望的输出尺寸
  • scale – 原始剪裁尺寸大小的范围
  • ratio – 原始裁剪纵横比的范围
  • interpolation – Default: PIL.Image.BILINEAR
  1. class torchvision.transforms.RandomSizedCrop(*args, **kwargs)

Note: 为了支持 RandomResizedCrop, 该变换已经被弃用.

  1. class torchvision.transforms.Grayscale(num_output_channels=1)

将图像转换为灰度图像.

参数:num_output_channels (int) – (1 or 3) 输出图像所期望的通道数量

返回值:灰度版本的输入. - 如果 num_output_channels == 1 : 返回的图像是 1 通道 - 如果 num_output_channels == 3 : 返回的图像是 3 通道, 并且 r == g == b

返回类型:PIL Image

  1. class torchvision.transforms.RandomGrayscale(p=0.1)

随机将图像转换为灰度图像, 概率为 p (default 0.1).

参数:p (float) – 图像应该被转换成灰度的概率.

返回值:灰度版本的输入图像的概率为 p, 不变的概率为(1-p) - 如果输入图像为1个通道: 则灰度版本是 1 通道 - 如果输入图像为3个通道: 则灰度版本是 3 通道, 并且 r == g == b

返回类型:PIL Image

  1. class torchvision.transforms.FiveCrop(size)

将给定的 PIL Image 裁剪成四个角落和中心裁剪

注解:

该变换返回一个图像元组, 并且数据集返回的输入和目标的数量可能不匹配. 请参阅下面的例子来处理这个问题.

参数:size (sequence 或 int) – 期望输出的裁剪尺寸. 如果 sizeint 类型的整数, 而不是像 (h, w) 这样类型的序列, 裁剪出来的图像是 (size, size) 这样的正方形的..

示例:

  1. >>> transform = Compose([
  2. >>> FiveCrop(size), # 一个 PIL Images 的列表
  3. >>> Lambda(lambda crops: torch.stack([ToTensor()(crop) for crop in crops])) # 返回一个4D Tensor
  4. >>> ])
  5. >>> #在你的测试循环可以如下操作:
  6. >>> input, target = batch # 输入是5DTensor,输出是2D
  7. >>> bs, ncrops, c, h, w = input.size()
  8. >>> result = model(input.view(-1, c, h, w)) # fuse batch size and ncrops
  9. >>> result_avg = result.view(bs, ncrops, -1).mean(1) # avg over crops
  1. class torchvision.transforms.TenCrop(size, vertical_flip=False)

将给定的 PIL Image 裁剪成四个角, 中心裁剪, 并加上这些的翻转版本(默认使用水平翻转)

注解:

该变换返回一个图像元组, 并且数据集返回的输入和目标的数量可能不匹配. 请参阅下面的例子来处理这个问题.

参数:

  • size (sequence 或 int) – 期望输出的裁剪尺寸. 如果 size(尺寸)是 int 类型的整数, 而不是像 (h, w) 这样类型的序列, 裁剪出来的图像是 (size, size) 这样的正方形的.
  • vertical_flip (bool) – 使用垂直翻转而不是水平的方式

示例:

  1. >>> transform = Compose([
  2. >>> TenCrop(size), # this is a list of PIL Images
  3. >>> Lambda(lambda crops: torch.stack([ToTensor()(crop) for crop in crops])) # returns a 4D tensor
  4. >>> ])
  5. >>> #In your test loop you can do the following:
  6. >>> input, target = batch # input is a 5d tensor, target is 2d
  7. >>> bs, ncrops, c, h, w = input.size()
  8. >>> result = model(input.view(-1, c, h, w)) # fuse batch size and ncrops
  9. >>> result_avg = result.view(bs, ncrops, -1).mean(1) # avg over crops
  1. class torchvision.transforms.Pad(padding, fill=0)

用指定的 “pad” 值填充指定的 PIL image.

参数:

  • padding (int 或 tuple) – 填充每个边框. 如果提供了一个 int 型的整数, 则用于填充所有边界. 如果提供长度为 2 的元组, 则这是分别在 左/右 和 上/下 的填充. 如果提供长度为 4 的元组, 则这是分别用于 左, 上, 右 和 下 部边界的填充.
  • fill – 像素填充. 默认值为 0. 如果长度为 3 的元组, 分别用于填充 R, G, B 通道.
  1. class torchvision.transforms.ColorJitter(brightness=0, contrast=0, saturation=0, hue=0)

随机更改图像的亮度, 对比度和饱和度.

参数:

  • brightness (float) – 亮度改变的范围. brightness_factor 从 [max(0, 1 - brightness), 1 + brightness]的范围中一致选择.
  • contrast (float) – 对比度改变的范围. contrast_factor 从 [max(0, 1 - contrast), 1 + contrast]的范围中一致选择.
  • saturation (float) – 饱和度改变的范围. saturation_factor 从[max(0, 1 - saturation), 1 + saturation]的范围中一致选择.
  • hue (float) – 色调改变的范围. hue_factor 从 [-hue, hue]的范围中一致选择. 应该 >=0 且 <= 0.5.

torch.*Tensor 上的变换

  1. class torchvision.transforms.Normalize(mean, std)

用均值和标准偏差对张量图像进行归一化. 给定均值: (M1,...,Mn) 和标准差: (S1,..,Sn) 用于 n 个通道, 该变换将标准化输入 torch.*Tensor 的每一个通道. 例如: input[channel] = (input[channel] - mean[channel]) / std[channel]

参数:

  • mean (sequence) – 每一个通道的均值序列.
  • std (sequence) – 每一个通道的标准差序列.
  1. __call__(tensor)

参数:tensor (Tensor) – 需要被归一化的大小为 (C, H, W)Tensor image.

返回值:归一化后的 Tensor image.

返回类型:Tensor

转换类型的变换

  1. class torchvision.transforms.ToTensor

转换一个 PIL Imagenumpy.ndarray 为 tensor(张量).

将范围 [0, 255] 中的 PIL Image 或 numpy.ndarray (H x W x C) 转换形状为 (C x H x W) , 值范围为 [0.0, 1.0] 的 torch.FloatTensor.

  1. __call__(pic)

参数:pic (PIL Image 或 numpy.ndarray) – 将要被转换为 tensor 的 Image.

返回值:转换后的 image.

返回类型:Tensor

  1. class torchvision.transforms.ToPILImage(mode=None)

转换一个 tensor 或 ndarray 为 PIL Image.

转换一个形状为(C x H x W) 的 torch.*Tensor 或一个形状为(H x W x C )的numpy ndarray 至一个 PIL Image ,同时保留值范围.

参数:mode (PIL.Image 模式) – 输入数据的色域和像素深度 (可选). 如果 modeNone (默认) ,这里对输入数据有一些假设: 1. 如果输入有3个通道, mode 假设为 RGB. 2. 如果输入有4个通道, mode 假设为 RGBA. 3. 如果输入有1个通道, mode 根据数据类型确定 (i,e, int, float, short).

  1. __call__(pic)

参数:pic (Tensor 或 numpy.ndarray) – 要转换为PIL Image的图像.

返回值:转换为PIL Image的图像.

返回类型:PIL Image

通用的变换

  1. class torchvision.transforms.Lambda(lambd)

应用一个用户定义的 Lambda 作为变换.

参数:lambd (function) – Lambda/function 以用于 transform.