news 2026/4/15 17:40:23

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
探索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函数将这些操作组合在一起,一次性完成所有的预处理操作。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 0:45:58

14、物联网-雾-云系统中分布式计算的匹配理论应用与挑战

物联网-雾-云系统中分布式计算的匹配理论应用与挑战 1. 多对多(MTM)匹配模型 1.1 计算资源分配模型 在三层物联网雾网络的计算资源分配问题中,考虑的网络由多个集群组成,每个集群包含一组雾节点(FN),并由一个集中式数据服务运营商(DSO)管理。FN负责为数据服务订阅者…

作者头像 李华
网站建设 2026/4/16 12:42:22

【爬虫框架-7】日志追踪实现

分布式爬虫全链路追踪系统设计与实现 一、背景与问题 在分布式爬虫系统中,一个初始请求可能会派生出数十子请求(列表页→详情页→评论页→下一页…),这些请求分布在不同的消费者进程中执行。如何追踪整个任务链的执行状态、性能…

作者头像 李华
网站建设 2026/4/16 12:44:50

3步搭建高效学术知识库:告别信息碎片化困扰

作为一名研究人员,你是否也经历过这样的困扰?📚 文献散落在不同文件夹,实验数据东一块西一块,项目进展难以系统追踪。这些信息碎片化的问题严重影响我们的科研效率。今天,我想和大家分享一套经过实践检验的…

作者头像 李华
网站建设 2026/4/16 11:06:28

Android权限管理的终极解决方案:XXPermissions组件化架构完全指南

Android权限管理的终极解决方案:XXPermissions组件化架构完全指南 【免费下载链接】XXPermissions Android 权限请求框架,已适配 Android 14 项目地址: https://gitcode.com/GitHub_Trending/xx/XXPermissions 还在为Android权限适配的复杂性而苦…

作者头像 李华
网站建设 2026/4/16 13:07:13

学生党突围数字经济:时间紧、预算少,如何靠AI兼职逆袭?

在数字经济浪潮中,人工智能确实越来越成为一项值得关注的技能。对于平时课业多、时间零散的学生来说,学点AI不仅能给简历加点分,说不定还能发展成一份灵活的兼职。不过,很多人一听说学AI就觉得“贵”和“难”,身边也有…

作者头像 李华