pytorch常见的Tensor类型详解
作者:fly_Xiaoma 时间:2022-10-25 19:34:01
Tensor有不同的数据类型,每种类型分别有对应CPU和GPU版本(HalfTensor除外)。默认的Tensor是FloatTensor,可通过torch.set_default_tensor_type修改默认tensor类型(如果默认类型为GPU tensor,则所有操作都将在GPU上进行)。
Tensor的类型对分析内存占用很有帮助,例如,一个size为(1000,1000,1000)的FloatTensor,它有1000*1000*1000=10^9个元素,每一个元素占用32bit/8=4Byte内存,所以共占用大约4GB内存/显存。HalfTensor是专为GPU版本设计的,同样的元素个数,显存占用只有HalfTensor的一半,所以可以极大缓解GPU显存不足的问题,但是由于HalfTensor所能表示的数值大小和精度有限,所以可能出现溢出等问题。
数据类型 | CPU Tensor | GPU Tensor |
32 bit 浮点 | torch.FloatTensor | torch.cuda.FloatTensor |
64 bit 浮点 | torch.DoubleTensor | torch.cuda.DoubleTensor |
16 bit 半精度浮点 | N/A | torch.cuda.HalfTensor |
8 bit 无符号整形(0~255) | torch.ByteTensor | torch.cuda.ByteTensor |
8 bit 有符号整形(-128~127) | torch.CharTensor | torch.cuda.CharTensor |
16 bit 有符号整形 | torch.ShortTensor | torch.cuda.ShortTensor |
32 bit 有符号整形 | torch.IntTensor | torch.cuda.IntTensor |
64 bit 有符号整形 | torch.LongTensor | torch.cuda LongTensor |
各数据类型之间可以互相转换,type(new_type)是通用的做法,同时还有float、long、half等快捷方法。CPU tensor和GPU tensor之间的互换是通过tensor.cuda和tensor.cpu的方法实现。
如:
#设置默认tensor,注意参数是字符串
torch.set_default_tensor_type('torch.IntTensor')
a=torch.Tensor(2,3)
print(a) #a现在是IntTensor
来源:https://blog.csdn.net/weixin_38664232/article/details/94192451
标签:pytorch,Tensor类型
0
投稿
猜你喜欢
使用Python docx修改word关键词颜色的操作
2022-01-15 01:47:34
IE8的一些CSS hack
2008-03-17 13:08:00
Django Form设置文本框为readonly操作
2023-11-11 03:03:43
分享一个pycharm专业版安装的永久使用方法
2023-04-27 17:26:34
在VSCode中配置PHP开发环境的实战步骤
2023-06-06 02:13:06
sqlserver数据库迁移后,孤立账号解决办法
2011-10-24 20:01:40
SQL Server连接失败错误及解决
2008-01-28 21:09:00
Python 中的lambda匿名函数和三元运算符
2023-04-21 05:22:18
asp如何正确显示数据库里同时存在的GB码和BIG5编码?
2010-06-28 18:26:00
Python2.7+pytesser实现简单验证码的识别方法
2022-01-18 02:37:33
Python数据读写之Python读写CSV文件
2023-04-04 00:59:46
python使用xauth方式登录饭否网然后发消息
2021-04-18 08:11:54
js版sliderBar(滑动条)控件
2008-10-18 15:59:00
js控制多图左右滚动切换效果代码分享
2023-08-28 00:14:32
ASP利用 xmlhttp 分块上传文件
2007-11-01 22:55:00
MySQL将select结果执行update的实例教程
2024-01-17 14:00:59
两个MySql服务的应用
2024-01-20 11:02:00
django使用django-apscheduler 实现定时任务的例子
2021-06-09 05:10:44
懒就要懒到底——鼠标自动点击(含时间判断)
2024-04-22 22:18:06
一文详解Golang 定时任务库 gron 设计和原理
2023-08-06 21:34:38