transforms.md 9.3 KB
Newer Older
W
mkdocs  
wizardforcel 已提交
1 2 3 4 5 6 7 8 9 10
# torchvision.transforms

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

```py
class torchvision.transforms.Compose(transforms)
```

将多个变换组合到一起.

W
wizardforcel 已提交
11
参数:`transforms (Transform 对象列表)` – 要组合的变换列表.
W
wizardforcel 已提交
12

W
mkdocs  
wizardforcel 已提交
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

Example

```py
>>> transforms.Compose([
>>>     transforms.CenterCrop(10),
>>>     transforms.ToTensor(),
>>> ])

```

## PIL Image 上的变换

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

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

W
wizardforcel 已提交
32
参数:
W
mkdocs  
wizardforcel 已提交
33

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

W
wizardforcel 已提交
37

W
mkdocs  
wizardforcel 已提交
38 39 40 41 42 43 44 45 46 47 48 49 50

```py
class torchvision.transforms.Scale(*args, **kwargs)
```

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

```py
class torchvision.transforms.CenterCrop(size)
```

在中心裁剪指定的 PIL Image.

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

W
mkdocs  
wizardforcel 已提交
53 54 55 56 57 58 59

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

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

W
wizardforcel 已提交
60
参数:
W
mkdocs  
wizardforcel 已提交
61

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

W
wizardforcel 已提交
65

W
mkdocs  
wizardforcel 已提交
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88

```py
class torchvision.transforms.RandomHorizontalFlip
```

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

```py
class torchvision.transforms.RandomVerticalFlip
```

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

```py
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.

W
wizardforcel 已提交
89
参数:
W
mkdocs  
wizardforcel 已提交
90

W
wizardforcel 已提交
91 92 93 94
*   `size` – 每条边的期望的输出尺寸
*   `scale` – 原始剪裁尺寸大小的范围
*   `ratio` – 原始裁剪纵横比的范围
*   `interpolation` – Default: PIL.Image.BILINEAR
W
mkdocs  
wizardforcel 已提交
95

W
wizardforcel 已提交
96

W
mkdocs  
wizardforcel 已提交
97 98 99 100 101 102 103 104 105 106 107 108 109

```py
class torchvision.transforms.RandomSizedCrop(*args, **kwargs)
```

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

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

将图像转换为灰度图像.

W
wizardforcel 已提交
110
参数:`num_output_channels (int)` – (1 or 3) 输出图像所期望的通道数量
W
wizardforcel 已提交
111 112 113

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

W
wizardforcel 已提交
114
返回类型:`PIL Image`
W
mkdocs  
wizardforcel 已提交
115 116 117 118 119 120 121

```py
class torchvision.transforms.RandomGrayscale(p=0.1)
```

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

W
wizardforcel 已提交
122
参数:`p (float)` – 图像应该被转换成灰度的概率.
W
wizardforcel 已提交
123 124 125

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

W
wizardforcel 已提交
126
返回类型:`PIL Image`
W
mkdocs  
wizardforcel 已提交
127 128 129 130 131 132 133

```py
class torchvision.transforms.FiveCrop(size)
```

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

W
wizardforcel 已提交
134
注解:
W
mkdocs  
wizardforcel 已提交
135 136 137

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

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

W
mkdocs  
wizardforcel 已提交
140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161

Example

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

```

```py
class torchvision.transforms.TenCrop(size, vertical_flip=False)
```

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

W
wizardforcel 已提交
162
注解:
W
mkdocs  
wizardforcel 已提交
163 164 165

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

W
wizardforcel 已提交
166
参数:
W
mkdocs  
wizardforcel 已提交
167

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

W
wizardforcel 已提交
171

W
mkdocs  
wizardforcel 已提交
172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193

Example

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

```

```py
class torchvision.transforms.Pad(padding, fill=0)
```

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

W
wizardforcel 已提交
194
参数:
W
mkdocs  
wizardforcel 已提交
195

W
wizardforcel 已提交
196 197
*   `padding (int 或 tuple)` – 填充每个边框. 如果提供了一个 int 型的整数, 则用于填充所有边界. 如果提供长度为 2 的元组, 则这是分别在 左/右 和 上/下 的填充. 如果提供长度为 4 的元组, 则这是分别用于 左, 上, 右 和 下 部边界的填充.
*   `fill` – 像素填充. 默认值为 0\. 如果长度为 3 的元组, 分别用于填充 R, G, B 通道.
W
mkdocs  
wizardforcel 已提交
198

W
wizardforcel 已提交
199

W
mkdocs  
wizardforcel 已提交
200 201 202 203 204 205 206

```py
class torchvision.transforms.ColorJitter(brightness=0, contrast=0, saturation=0, hue=0)
```

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

W
wizardforcel 已提交
207
参数:
W
mkdocs  
wizardforcel 已提交
208

W
wizardforcel 已提交
209 210 211 212
*   `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.
W
mkdocs  
wizardforcel 已提交
213

W
wizardforcel 已提交
214

W
mkdocs  
wizardforcel 已提交
215 216 217 218 219 220 221 222 223

## torch.*Tensor 上的变换

```py
class torchvision.transforms.Normalize(mean, std)
```

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

W
wizardforcel 已提交
224
参数:
W
mkdocs  
wizardforcel 已提交
225

W
wizardforcel 已提交
226 227
*   `mean (sequence)` – 每一个通道的均值序列.
*   `std (sequence)` – 每一个通道的标准差序列.
W
mkdocs  
wizardforcel 已提交
228

W
wizardforcel 已提交
229

W
mkdocs  
wizardforcel 已提交
230 231 232 233 234

```py
__call__(tensor)
```

W
wizardforcel 已提交
235
参数:`tensor (Tensor)` – 需要被归一化的大小为 (C, H, W)Tensor image.
W
wizardforcel 已提交
236 237 238

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

W
wizardforcel 已提交
239
返回类型:`Tensor`
W
mkdocs  
wizardforcel 已提交
240 241 242 243 244 245 246 247 248 249 250 251 252 253 254

## 转换类型的变换

```py
class torchvision.transforms.ToTensor
```

转换一个 `PIL Image` 或 `numpy.ndarray` 为 tensor(张量).

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

```py
__call__(pic)
```

W
wizardforcel 已提交
255
参数:`pic (PIL Image 或 numpy.ndarray)` – 将要被转换为 tensor 的 Image.
W
wizardforcel 已提交
256 257 258

返回值:转换后的 image.

W
wizardforcel 已提交
259
返回类型:`Tensor`
W
mkdocs  
wizardforcel 已提交
260 261 262 263 264 265 266 267 268

```py
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 ,同时保留值范围.

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

W
mkdocs  
wizardforcel 已提交
271 272 273 274 275

```py
__call__(pic)
```

W
wizardforcel 已提交
276
参数:`pic (Tensor 或 numpy.ndarray)` – 要转换为PIL Image的图像.
W
wizardforcel 已提交
277 278 279

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

W
wizardforcel 已提交
280
返回类型:`PIL Image`
W
mkdocs  
wizardforcel 已提交
281 282 283 284 285 286 287 288 289

## 通用的变换

```py
class torchvision.transforms.Lambda(lambd)
```

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

W
wizardforcel 已提交
290
参数:`lambd (function)` – Lambda/function 以用于 transform.