当前位置: 首页 > news >正文

探索Transform的中不同参数的用法

1问题

1,ToTensor:将PIL Image或numpy.ndarray转换为torch.FloatTensor,并将其归一化到[0.0, 1.0]范围内。

2,Normalize:将PIL Image或numpy.ndarray转换为torch.FloatTensor,并将其归一化到[-1.0, 1.0]范围内。

3,Resize:调整图像大小。

4,CenterCrop:将给定的PIL Image进行中心切割,得到给定的size。

5,Compose:将多个变换组合在一起。

6,RandomCrop:从图像中随机裁剪出一定大小的区域。

2 方法

数据转换:transforms.ToTensor()

ToTensor是transforms模块中的一个函数,用于将PIL Image或numpy.ndarray类型的数据转换为torch.FloatTensor类型。在Pytorch中,图像数据通常以PIL Image的形式存在,而模型训练时需要的数据格式为torch.FloatTensor

from torchvision import transforms # 创建一个ToTensor实例


to_tensor = transforms.ToTensor() # 对图像进行ToTensor转换
image = Image.open('example.jpg')
image_tensor = to_tensor(image)

数据归一化:transforms.Normalize()

Normalize是transforms模块中的一个函数,用于将PIL Image或numpy.ndarray类型的数据进行归一化处理。归一化是将数据缩放到一个特定的范围,通常是[0, 1]或[-1, 1]。在图像处理中,归一化可以使得不同尺度的图像具有相同的尺度,从而方便模型的训练和预测。

from torchvision import transforms # 创建一个Normalize实例,指定均值和标准差


normalize = transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]) # 对图像进行Normalize转换
image = Image.open('example.jpg')
normalized_image = normalize(image)

调整图像大小transforms.Resize()

Resize是transforms模块中的一个函数,用于调整图像的大小。在图像处理中,我们需要将不同大小的图像输入到模型中进行训练和预测

from torchvision import transforms # 创建一个Resize实例,指定目标尺寸


resize = transforms.Resize((224, 224)) # 对图像进行Resize转换
image = Image.open('example.jpg')
resized_image = resize(image)

从图像中心裁剪出指定大小的区域transforms.CenterCrop()

CenterCrop是transforms模块中的一个函数,用于从图像中心裁剪出指定大小的区域。在图像处理中,我们需要将不同大小的图像输入到模型中进行训练和预测。因此,我们需要对图像进行大小调整,使其具有相同的尺寸。

from torchvision import transforms # 创建一个CenterCrop实例,指定目标尺寸


center_crop = transforms.CenterCrop((224, 224)) # 对图像进行CenterCrop转换
image=Image.open('example.jpg') center_cropped_image = center_crop(image)

对图像进行多种不同的操作:transforms.Compose()

Compose是transforms模块中的一个函数,用于将多个变换组合在一起。在图像处理中,我们可能需要对图像进行多种不同的操作,例如缩放、裁剪、旋转等

from torchvision import transforms # 创建一个Compose实例,指定多个变换操作


compose=transforms.Compose([ transforms.Resize((224, 224)),transforms.CenterCrop(224), transforms.ToTensor(), transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]) ]) # 对图像进行Compose转换 image = Image.open('example.jpg')
composed_image = compose(image)

从图像中随机裁剪出指定大小的区域transforms.RandomCrop()

RandomCrop是transforms模块中的一个函数,用于从图像中随机裁剪出指定大小的区域

from torchvision import transforms # 创建一个RandomCrop实例,指定目标尺寸


random_crop = transforms.RandomCrop((224, 224)) # 对图像进行RandomCrop转换
image=Image.open('example.jpg') random_cropped_image = random_crop(image)

3结语

torchvision.trantransform是PyTorch中用于数据预处理的模块,它提供了多种常用的数据转换操作,如缩放、裁剪、旋转等。在图像处理中,我们通常需要将不同大小的图像输入到模型中进行训练和预测。因此,我们需要对图像进行大小调整,使其具有相同的尺寸。通过使用这些函数,我们可以方便地对图像进行预处理,使其符合模型的要求。例如,在ImageNet数据集上训练卷积神经网络时,我们需要将所有图像缩放到指定的大小(224x224),并进行归一化处理。这时,我们可以使用Compose函数将这些操作组合在一起,一次性完成所有的预处理操作。

http://www.cnnetsun.cn/news/74586.html

相关文章:

  • 【爬虫框架-8】其他
  • Vue-next-admin终极指南:打造现代化后台管理系统的完整解决方案
  • vgmstream终极指南:游戏音频转换与播放全攻略
  • vgmstream音频解码神器:游戏音频格式转换终极指南
  • 印象大红袍通过上市聆讯:上半年营收5588万 利润678万
  • 蔡东青创办的奥动冲刺港股:靠换电半年营收3.2亿同比降32% 亏1.57亿 蔚来资本是股东
  • 基于Next.js的LobeChat为何成为GitHub星标项目?技术架构全拆解
  • 广合科技冲刺港股:前9个月营收38亿净利7亿 刚斥资3.2亿买楼
  • Vue Signature Pad电子签名组件完整使用指南:快速集成步骤与实用配置技巧
  • Joy-Con Toolkit终极指南:如何轻松自定义你的游戏手柄
  • 暗黑破坏神II存档编辑器:多版本兼容的角色定制解决方案
  • [自动化办公] 【Python】【低代码】在明道云中实现无需 pandas 的数据聚合与 HTML 表格生成技巧
  • OpenFace完整指南:从零开始掌握面部行为分析终极工具
  • Python协同过滤算法 音乐推荐系统_731w447o 论坛 浏览历史
  • 17、图像深度处理技术:从理论到实践
  • GitHub项目Star暴涨:Stable Diffusion 3.5 FP8成AIGC开发者新宠
  • Windows显示器亮度控制终极方案:Twinkle Tray完整使用手册
  • VideoDownloadHelper 终极使用指南:轻松下载网页视频资源
  • 高效STL转STEP工具:3D格式转换的完整解决方案
  • throw new Exception 如何指定返回code
  • 如何利用Cangaroo开源工具高效解决CAN总线开发难题
  • 百度网盘秒传脚本完全指南:快速上手极速生成功能
  • 芯片价格战:成本才是王道
  • layerdivider:AI图像分层革命,让设计效率飙升10倍
  • 收到工资1002415.13元,爱你华为。
  • Windows 11精简终极教程:三步打造高性能轻量系统
  • 全面解锁Honey Select 2游戏潜能的200+插件整合方案
  • ComfyUI与ONNX Runtime集成:跨框架模型支持
  • WebSite-Downloader 网站下载器终极指南:5分钟快速上手完整教程
  • 什么是公有云