PyTorch--transforms的二十二个方法

本文详细介绍了PyTorch中用于图像数据增强的各种变换,包括随机裁剪、中心裁剪、随机长宽比裁剪、翻转和旋转等,以及如何通过这些变换实现更灵活的数据增强策略,如RandomChoice、RandomApply和RandomOrder,以提高模型训练的鲁棒性。
部署运行你感兴趣的模型镜像

一、裁剪——Crop

1.随机裁剪:transforms.RandomCrop

class torchvision.transforms.RandomCrop(size, padding=None, pad_if_needed=False, fill=0, padding_mode=‘constant’)
功能:依据给定的size随机裁剪
参数:
size- (sequence or int),若为sequence,则为(h,w),若为int,则(size,size)
padding-(sequence or int, optional),此参数是设置填充多少个pixel。
当为int时,图像上下左右均填充int个,例如padding=4,则上下左右均填充4个pixel,若为3232,则会变成4040。
当为sequence时,若有2个数,则第一个数表示左右扩充多少,第二个数表示上下的。当有4个数时,则为左,上,右,下。
fill- (int or tuple) 填充的值是什么(仅当填充模式为constant时有用)。int时,各通道均填充该值,当长度为3的tuple时,表示RGB通道需要填充的值。
padding_mode- 填充模式,这里提供了4种填充模式,1.constant,常量。2.edge 按照图片边缘的像素值来填充。3.reflect,暂不了解。 4. symmetric,暂不了解。

2.中心裁剪:transforms.CenterCrop

class torchvision.transforms.CenterCrop(size)
功能:依据给定的size从中心裁剪
参数:
size- (sequence or int),若为sequence,则为(h,w),若为int,则(size,size)

3.随机长宽比裁剪:transforms.RandomResizedCrop

class torchvision.transforms.RandomResizedCrop(size, scale=(0.08, 1.0), ratio=(0.75, 1.3333333333333333), interpolation=2)
功能:随机大小,随机长宽比裁剪原始图片,最后将图片resize到设定好的size
参数:
size- 输出的分辨率
scale- 随机crop的大小区间,如scale=(0.08, 1.0),表示随机crop出来的图片会在的0.08倍至1倍之间。
ratio- 随机长宽比设置
interpolation- 插值的方法,默认为双线性插值(PIL.Image.BILINEAR)

4.上下左右中心裁剪:transforms.FiveCrop

class torchvision.transforms.FiveCrop(size)
功能:对图片进行上下左右以及中心裁剪,获得5张图片,返回一个4D-tensor
参数:
size- (sequence or int),若为sequence,则为(h,w),若为int,则(size,size)

5.上下左右中心裁剪后翻转: transforms.TenCrop

class torchvision.transforms.TenCrop(size, vertical_flip=False)
功能:对图片进行上下左右以及中心裁剪,然后全部翻转(水平或者垂直),获得10张图片,返回一个4D-tensor。
参数:
size- (sequence or int),若为sequence,则为(h,w),若为int,则(size,size)
vertical_flip (bool) - 是否垂直翻转,默认为flase,即默认为水平翻转

二、翻转和旋转——Flip and Rotation

6.依概率p水平翻转:transforms.RandomHorizontalFlip(p=0.5)

class torchvision.transforms.RandomHorizontalFlip(p=0.5)
功能:依据概率p对PIL图片进行水平翻转
参数:
p- 概率,默认值为0.5

7.依概率p垂直翻转:transforms.RandomVerticalFlip(p=0.5)

class torchvision.transforms.RandomVerticalFlip(p=0.5)
功能:依据概率p对PIL图片进行垂直翻转
参数:
p- 概率,默认值为0.5

8.随机旋转:transforms.RandomRotation

class torchvision.transforms.RandomRotation(degrees, resample=False, expand=False, center=None)
功能:依degrees随机旋转一定角度
参数:
degress- (sequence or float or int) ,若为单个数,如 30,则表示在(-30,+30)之间随机旋转
若为sequence,如(30,60),则表示在30-60度之间随机旋转
resample- 重采样方法选择,可选 PIL.Image.NEAREST, PIL.Image.BILINEAR, PIL.Image.BICUBIC,默认为最近邻
expand- ?
center- 可选为中心旋转还是左上角旋转

三、图像变换

9.resize:transforms.Resize

class torchvision.transforms.Resize(size, interpolation=2)
功能:重置图像分辨率
参数:
size- If size is an int, if height > width, then image will be rescaled to (size * height / width, size),所以建议size设定为h*w
interpolation- 插值方法选择,默认为PIL.Image.BILINEAR

10.标准化:transforms.Normalize

class torchvision.transforms.Normalize(mean, std)
功能:对数据按通道进行标准化,即先减均值,再除以标准差,注意是 hwc

11.转为tensor,并归一化至[0-1]:transforms.ToTensor

class torchvision.transforms.ToTensor
功能:将PIL Image或者 ndarray 转换为tensor,并且归一化至[0-1]
注意事项:归一化至[0-1]是直接除以255,若自己的ndarray数据尺度有变化,则需要自行修改。

12.填充:transforms.Pad

class torchvision.transforms.Pad(padding, fill=0, padding_mode=‘constant’)
功能:对图像进行填充
参数:
padding-(sequence or int, optional),此参数是设置填充多少个pixel。
当为int时,图像上下左右均填充int个,例如padding=4,则上下左右均填充4个pixel,若为3232,则会变成4040。
当为sequence时,若有2个数,则第一个数表示左右扩充多少,第二个数表示上下的。当有4个数时,则为左,上,右,下。
fill- (int or tuple) 填充的值是什么(仅当填充模式为constant时有用)。int时,各通道均填充该值,当长度为3的tuple时,表示RGB通道需要填充的值。
padding_mode- 填充模式,这里提供了4种填充模式,1.constant,常量。2.edge 按照图片边缘的像素值来填充。3.reflect, 4. symmetric,

13.修改亮度、对比度和饱和度:transforms.ColorJitter

class torchvision.transforms.ColorJitter(brightness=0, contrast=0, saturation=0, hue=0)
功能:修改修改亮度、对比度和饱和度

14.转灰度图:transforms.Grayscale

class torchvision.transforms.Grayscale(num_output_channels=1)
功能:将图片转换为灰度图
参数:
num_output_channels- (int) ,当为1时,正常的灰度图,当为3时, 3 channel with r == g == b

15.线性变换:transforms.LinearTransformation()

class torchvision.transforms.LinearTransformation(transformation_matrix)
功能:对矩阵做线性变化,可用于白化处理! whitening: zero-center the data, compute the data covariance matrix
参数:
transformation_matrix (Tensor) – tensor [D x D], D = C x H x W

16.仿射变换:transforms.RandomAffine

class torchvision.transforms.RandomAffine(degrees, translate=None, scale=None, shear=None, resample=False, fillcolor=0)
功能:仿射变换

17.依概率p转为灰度图:transforms.RandomGrayscale

class torchvision.transforms.RandomGrayscale(p=0.1)
功能:依概率p将图片转换为灰度图,若通道数为3,则3 channel with r == g == b

18.将数据转换为PILImage:transforms.ToPILImage

class torchvision.transforms.ToPILImage(mode=None)
功能:将tensor 或者 ndarray的数据转换为 PIL Image 类型数据
参数:
mode- 为None时,为1通道, mode=3通道默认转换为RGB,4通道默认转换为RGBA

19.transforms.Lambda

Apply a user-defined lambda as a transform.

四、对transforms操作,使数据增强更灵活

20 transforms.RandomChoice(transforms)

功能:从给定的一系列transforms中选一个进行操作,randomly picked from a list

21 transforms.RandomApply(transforms, p=0.5)

功能:给一个transform加上概率,以一定的概率执行该操作

22 transforms.RandomOrder

功能:将transforms中的操作顺序随机打乱

您可能感兴趣的与本文相关的镜像

PyTorch 2.5

PyTorch 2.5

PyTorch
Cuda

PyTorch 是一个开源的 Python 机器学习库,基于 Torch 库,底层由 C++ 实现,应用于人工智能领域,如计算机视觉和自然语言处理

你输入的命令: ```bash conda install pytorch torchvision torchaudio pytorch-cuda=11.8 -c pytorch -c nvidia ``` 是一个 **使用 Conda 安装 PyTorch 深度学习框架及其相关组件,并启用 CUDA 11.8 支持** 的标准命令。下面我将详细解释这个命令的每一部分、它的作用、适用场景以及常见问题和解决方案。 --- ## ✅ 命令详解 ```bash conda install pytorch torchvision torchaudio pytorch-cuda=11.8 -c pytorch -c nvidia ``` | 部分 | 含义 | |------|------| | `conda install` | 使用 Anaconda/Miniconda 的包管理器安装软件 | | `pytorch` | 主体:PyTorch 框架(用于张量计算和深度神经网络) | | `torchvision` | 扩展库:提供图像数据处理工具(如 transforms)、预训练模型(ResNet 等)和常用数据集(CIFAR, ImageNet) | | `torchaudio` | 扩展库:音频处理支持(加载 WAV 文件、频谱图等) | | `pytorch-cuda=11.8` | 指定使用 NVIDIA CUDA 11.8 版本进行 GPU 加速运算 | | `-c pytorch` | 添加官方 [PyTorch 的 Conda 渠道](https://anaconda.org/pytorch)(必须!否则找不到包) | | `-c nvidia` | 添加 NVIDIA 的 Conda 渠道,用于获取 CUDA 相关依赖 | > 🔔 这个命令会自动安装与 CUDA 11.8 兼容的 PyTorch 构建版本,让你可以在支持的 GPU 上运行深度学习模型。 --- ## 📦 安装了哪些内容? | 包名 | 功能 | |------|------| | `pytorch` | 核心深度学习框架,支持动态计算图、自动求导、GPU 计算 | | `torchvision` | 图像处理模块:<br>• `transforms` 数据增强<br>• `models.resnet50()` 等预训练模型<br>• `datasets.ImageFolder` 加载图片数据 | | `torchaudio` | 音频处理模块:<br>• 读取 `.wav` 文件<br>• 提取梅尔频谱图(Mel-spectrogram)<br>• 集成 Kaldi 工具 | | `pytorch-cuda=11.8` | 不是独立库,而是“虚拟包”,用来触发 Conda 安装包含 CUDA 支持的 PyTorch 构建版本 | --- ## 💻 示例:验证是否安装成功 安装完成后,在 Python 中运行以下代码测试: ```python import torch print("PyTorch version:", torch.__version__) print("CUDA available:", torch.cuda.is_available()) print("CUDA version:", torch.version.cuda) print("Number of GPUs:", torch.cuda.device_count()) if torch.cuda.is_available(): print("Current GPU:", torch.cuda.get_device_name(0)) ``` ✅ 正常输出示例(表示 GPU 可用): ``` PyTorch version: 2.0.1 CUDA available: True CUDA version: 11.8 Number of GPUs: 1 Current GPU: NVIDIA GeForce RTX 3080 ``` ❌ 如果 `CUDA available: False`,说明没有正确启用 GPU,请查看下方“常见问题”。 --- ## ⚠️ 常见问题与解决方法 ### ❌ 问题 1:`CondaError: Packages missing in current channels` > 报错原因:未添加 `-c pytorch` 或网络连接失败 ✅ 解决方案: 确保完整命令中包含两个渠道: ```bash conda install pytorch torchvision torchaudio pytorch-cuda=11.8 -c pytorch -c nvidia ``` 不要漏掉 `-c pytorch`! 也可以尝试先更新 conda: ```bash conda update conda ``` --- ### ❌ 问题 2:CUDA 不可用(`torch.cuda.is_available()` 返回 `False`) 请检查以下几点: 1. **是否有 NVIDIA 显卡?** - Intel/AMD 集成显卡不支持 CUDA 2. **是否安装了最新版 NVIDIA 驱动?** - 打开命令提示符运行: ```bash nvidia-smi ``` - 输出应显示驱动版本和 GPU 信息 3. **驱动版本是否支持 CUDA 11.8?** - 一般要求驱动版本 ≥ 520.xx 4. **是否在正确的环境中激活?** ```bash conda activate your_env_name ``` --- ### 🐍 替代方式:使用 pip 安装(推荐速度更快) 如果你发现 conda 安装慢或冲突多,可以用 pip: ```bash pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118 ``` - `cu118` 表示 CUDA 11.8 - 更快、更灵活,社区主流选择 > 官方推荐安装方式见:👉 https://pytorch.org/get-started/locally/ --- ## 🧩 推荐做法:创建独立虚拟环境安装 避免污染 base 环境,建议创建专属环境: ```bash # 1. 创建新环境(名为 pytorch_env) conda create -n pytorch_env python=3.9 # 2. 激活环境 conda activate pytorch_env # 3. 安装 PyTorch + CUDA 支持 conda install pytorch torchvision torchaudio pytorch-cuda=11.8 -c pytorch -c nvidia ``` 这样你的项目依赖完全隔离,安全又干净。 --- ## 🖼️ 总结图示 ``` 你的电脑 ├── 操作系统 Windows/Linux/macOS ├── NVIDIA 显卡 + 驱动 ├── CUDA Driver (由 nvidia-smi 显示) └── Anaconda └── 虚拟环境 pytorch_env ├── python=3.9 ├── pytorch (with CUDA 11.8 support) ├── torchvision └── torchaudio → 在 PyCharm/Jupyter 中设置解释器为此环境即可使用 ``` ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值