pytorch 把图片数据转化成tensor的操作


Posted in Python onMarch 04, 2021

摘要:

在图像识别当中,一般步骤是先读取图片,然后把图片数据转化成tensor格式,再输送到网络中去。本文将介绍如何把图片转换成tensor。

一、数据转换

把图片转成成torch的tensor数据,一般采用函数:torchvision.transforms。通过一个例子说明,先用opencv读取一张图片,然后在转换;注意一点是:opencv储存图片的格式和torch的储存方式不一样,opencv储存图片格式是(H,W,C),而torch储存的格式是(C,H,W)。

import torchvision.transforms as transforms
import cv2 as cv
img = cv.imread('image/000001.jpg')
print(img.shape)  # numpy数组格式为(H,W,C)
transf = transforms.ToTensor()
img_tensor = transf(img) # tensor数据格式是torch(C,H,W)
print(img_tensor.size())

pytorch 把图片数据转化成tensor的操作

注意:使用torchvision.transforms时要注意一下,其子函数 ToTensor() 是没有参数输入的,以下用法是会报错的

img_tensor = transforms.ToTensor(img)

必须是先定义和赋值转换函数,再调用并输入参数,正确用法:

img = cv.imread('image/000001.jpg')
transf = transforms.ToTensor()
img_tensor = transf(img)

再转换过程中正则化

在使用 transforms.ToTensor() 进行图片数据转换过程中会对图像的像素值进行正则化,即一般读取的图片像素值都是8 bit 的二进制,那么它的十进制的范围为 [0, 255],而正则化会对每个像素值除以255,也就是把像素值正则化成 [0.0, 1.0]的范围。通过例子理解一下:

import torchvision.transforms as transforms
import cv2 as cv
img = cv.imread('image/000001.jpg')
transf = transforms.ToTensor()
img_tensor = transf(img)
print('opencv', img)
print('torch', img_tensor)

pytorch 把图片数据转化成tensor的操作

pytorch 把图片数据转化成tensor的操作

三、自行修改正则化的范围

使用transforms.Compose函数可以自行修改正则化的范围,下面举个例子正则化成 [-1.0, 1.0]

transf2 = transforms.Compose(
  [
    transforms.ToTensor(),
    transforms.Normalize(mean=(0.5, 0.5, 0.5), std=(0.5, 0.5, 0.5))
  ]
)
img_tensor2 = transf2(img)
print(img_tensor2)

pytorch 把图片数据转化成tensor的操作

计算方式就是:

C=(C-mean)/ std

C为每个通道的所有像素值,彩色图片为三通道图像(BGR),所以mean和std是三个数的数组。

使用transforms.ToTensor()时已经正则化成 [0,0, 0,1]了,那么(0.0 - 0.5)/0.5=-1.0,(1.0 - 0.5)/0.5=1.0,所以正则化成 [-1.0, 1.0]

补充:Python: 记录一个关于图片直接转化为pytorch.tensor和numpy.array的不同之处的问题

img = Image.open(img_path).convert("RGB")
img2 = torchvision.transforms.functional.to_tensor(img)
print(img2)
img1 = np.array(img)
print(img1)

输出是这样的:

pytorch 把图片数据转化成tensor的操作

不仅shape不一样,而且值也是不一样的。

解释如下:

tensor = torch.from_numpy(np.asarray(PIL.Image.open(path))).permute(2, 0, 1).float() / 255
tensor = torchvision.transforms.functional.to_tensor(PIL.Image.open(path)) # 两种方法是一样的

PIL.Image.open()得到HWC格式,直接使用numpy 去转换得到(h,w,c)格式,而用to_tensor得到(c,h,w)格式且值已经除了255。

byte()相当于to(torch.uint8),tensor.numpy()是把tensor 转化为numpy.array格式。

在这里需要注意的是PIL和OPENCV的图像读取得到的格式都是HWC格式,一般模型训练使用的是CHW格式, H为Y轴是竖直方向,W为X轴水平方向。

且torchvision.transforms.functional.to_tensor()对所有输入都是有变换操作。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。如有错误或未考虑完全的地方,望不吝赐教。

Python 相关文章推荐
Python的print用法示例
Feb 11 Python
Python中__init__和__new__的区别详解
Jul 09 Python
在Ubuntu系统下安装使用Python的GUI工具wxPython
Feb 18 Python
Python检查和同步本地时间(北京时间)的实现方法
Dec 03 Python
python内存监控工具memory_profiler和guppy的用法详解
Jul 29 Python
python并发编程多进程 模拟抢票实现过程
Aug 20 Python
django框架auth模块用法实例详解
Dec 10 Python
k-means 聚类算法与Python实现代码
Jun 01 Python
使用python实现名片管理系统
Jun 18 Python
python 实现简易的记事本
Nov 30 Python
Python爬虫框架之Scrapy中Spider的用法
Jun 28 Python
Python图像处理库PIL详细使用说明
Apr 06 Python
pytorch 计算Parameter和FLOP的操作
Mar 04 #Python
从Pytorch模型pth文件中读取参数成numpy矩阵的操作
Mar 04 #Python
python 如何用urllib与服务端交互(发送和接收数据)
Mar 04 #Python
python 求两个向量的顺时针夹角操作
Mar 04 #Python
python 制作磁力搜索工具
Mar 04 #Python
python抢购软件/插件/脚本附完整源码
Mar 04 #Python
Python 求向量的余弦值操作
Mar 04 #Python
You might like
40年前的这部特摄片恐龙特级克塞号80后的共同回忆
2020/03/08 日漫
php对gzip文件或者字符串解压实例参考
2008/07/25 PHP
PHP文章按日期(月日)SQL归档语句
2012/11/29 PHP
修改WordPress中文章编辑器的样式的方法详解
2015/12/15 PHP
Yii框架数据模型的验证规则rules()被执行的方法
2016/12/02 PHP
Thinkphp 框架扩展之数据库驱动常用方法小结
2020/04/23 PHP
基于jquery的无刷新分页技术
2011/06/11 Javascript
Javascript闭包用法实例分析
2015/01/23 Javascript
JS+CSS实现模仿浏览器网页字符查找功能的方法
2015/02/26 Javascript
在AngularJS中如何使用谷歌地图把当前位置显示出来
2016/01/25 Javascript
js提交form表单,并传递参数的实现方法
2016/05/25 Javascript
jQuery删除节点用法示例(remove方法)
2016/09/08 Javascript
js实现图片360度旋转
2017/01/22 Javascript
vue组件 $children,$refs,$parent的使用详解
2017/07/31 Javascript
react-native 圆弧拖动进度条实现的示例代码
2018/04/12 Javascript
vue项目部署到nginx/tomcat服务器的实现
2019/08/26 Javascript
JS实现躲避粒子小游戏
2020/06/18 Javascript
[59:48]DOTA2-DPC中国联赛 正赛 VG vs Magma BO3 第一场 1月26日
2021/03/11 DOTA
关于Python 3中print函数的换行详解
2017/08/08 Python
对python数据切割归并算法的实例讲解
2018/12/12 Python
Python爬虫实现获取动态gif格式搞笑图片的方法示例
2018/12/24 Python
详解Django+uwsgi+Nginx上线最佳实战
2019/03/14 Python
PyQt4 treewidget 选择改变颜色,并设置可编辑的方法
2019/06/17 Python
Python3+Requests+Excel完整接口自动化测试框架的实现
2019/10/11 Python
基于PyTorch的permute和reshape/view的区别介绍
2020/06/18 Python
20行Python代码实现一款永久免费PDF编辑工具的实现
2020/08/27 Python
J2EE的优越性主要表现在哪些方面
2016/03/28 面试题
生物科学专业个人求职信范文
2013/12/05 职场文书
工业设计专业个人求职信范文
2013/12/28 职场文书
高中自我评价范文
2014/01/27 职场文书
火箭队口号
2014/06/18 职场文书
音乐课《小猫钓鱼》教学反思
2016/02/18 职场文书
2019年销售人员的职业生涯规划书
2019/03/25 职场文书
七年级之开学家长寄语35句
2019/09/05 职场文书
祝福语集锦:朋友新店开业祝福语
2019/12/10 职场文书
动画电影《龙珠超 超级英雄》延期上映
2022/03/20 日漫