網站首頁 編程語言 正文
關于Tensor的數據類型說明
1. 32位浮點型:torch.FloatTensor
a=torch.Tensor( [[2,3],[4,8],[7,9]], )
print "a:",a
print "a.size():",a.size()
print "a.dtype:",a.dtype
b=torch.FloatTensor( [[2,3],[4,8],[7,9]] )
print "b:",b
print "b.shape:",b.shape
print "b.dtype:",b.dtype
可以看出?torch.FloatTensor 是32位float類型,并且torch.Tensor默認的數據類型是32位float類型。
2. 64位浮點型:torch.DoubleTensor
b=torch.DoubleTensor( [[2,3],[4,8],[7,9]] )
print "b:",b
print "b.shape:",b.shape
print "b.dtype:",b.dtype
?3. 16位整型:torch.ShortTensor
b=torch.ShortTensor( [[2,3],[4,8],[7,9]] )
print "b:",b
print "b.shape:",b.shape
print "b.dtype:",b.dtype
4.? 32位整型:torch.IntTensor
b=torch.IntTensor( [[2,3],[4,8],[7,9]] )
print "b:",b
print "b.shape:",b.shape
print "b.dtype:",b.dtype
5. 64位整型:torch.LongTensor
b=torch.LongTensor( [[2,3],[4,8],[7,9]] )
print "b:",b
print "b.shape:",b.shape
print "b.dtype:",b.dtype
6. 快速創建Tensor
(1)?torch.zeros()
a=torch.zeros( size=(4,5),dtype=torch.float32 )
print a
print a.shape
print a.dtype
(2)?torch.randn()
a=torch.randn( size=(4,5),dtype=torch.float32 )
print a
print a.shape
print a.dtype
7. Tensor索引方式,參考numpy
8. Tensor和numpy數組轉換:
(1) Tensor轉numpy,
a=torch.randn( size=(4,5),dtype=torch.float32 )
print a
print a.shape
print a.dtype
b= a.numpy()
print b
print b.shape
print b.dtype
(2) numpy轉Tensor,
a=np.random.randn(4,3)
print a
print a.shape
print a.dtype
b=torch.from_numpy( a )
print b
print b.shape
print b.dtype
9.更改Tensor的數據類型,
a=torch.FloatTensor( (3,2) )
print a
print a.shape
print a.dtype
a.int()
print a
print a.shape
print a.dtype
10. GPU加速,如果pytorch支持GPU加速,可以加Tensor放到GPU執行,
if torch.cuda.is_available():
a_cuda = a.cuda()
pytorch Tensor變形函數
view(), resize(), reshape() 在不改變原tensor數據的情況下修改tensor的形狀,前后要求元素總數一致,且前后tensor共享內存
如果想要直接改變Tensor的尺寸,可以使用resize_()的原地操作函數。
在resize_()函數中,如果超過了原Tensor的大小則重新分配內存,多出部分置0,如果小于原Tensor大小則剩余的部分仍然會隱藏保留。
transpose()函數可以將指定的兩個維度的元素進行轉置,而permute()函數則可以按照給定的維度進行維度變換。
在實際的應用中,經常需要增加或減少Tensor的維度,尤其是維度為1的情況,這時候可以使用squeeze()與unsqueeze()函數,前者用于去除size為1的維度,而后者則是將指定的維度的size變為1。
有時需要采用復制元素的形式來擴展Tensor的維度,這時expand就派上用場了。
expand()函數將size為1的維度復制擴展為指定大小,也可以使用expand_as()函數指定為示例Tensor的維度。
注意:在進行Tensor操作時,有些操作如transpose()、permute()等可能會把Tensor在內存中變得不連續,而有些操作如view()等是需要Tensor內存連續的,這種情況下需要使用contiguous()操作先將內存變為連續的。在PyTorch v0.4版本中增加了reshape()操作,可以看做是Tensor.contiguous().view()
Tensor的排序與取極值
排序函數sort(),選擇沿著指定維度進行排序,返回排序后的Tensor及對應的索引位置。
max()與min()函數則是沿著指定維度選擇最大與最小元素,返回該元素及對應的索引位置。
Tensor與NumPy轉換
Tensor與NumPy可以高效地進行轉換,并且轉換前后的變量共享內存。在進行PyTorch不支持的操作時,甚至可以曲線救國,將Tensor轉換為NumPy類型,操作后再轉為Tensor。
原文鏈接:https://blog.csdn.net/moshiyaofei/article/details/89703161
相關推薦
- 2022-05-06 Matplotlib安裝與配置
- 2022-06-02 Python中函數的創建與調用你了解嗎_python
- 2022-12-04 Android?SurfaceView與TextureView使用方法詳細講解_Android
- 2022-10-06 react?路由權限動態菜單方案配置react-router-auth-plus_React
- 2022-05-27 詳解Python實現字典合并的四種方法_python
- 2022-03-28 python?Pandas中數據的合并與分組聚合_python
- 2022-11-17 Python+OpenCV之圖像輪廓詳解_python
- 2022-08-11 Go語言Grpc?Stream的實現_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支