這篇文章將為大家詳細講解有關Python中Pytorch怎么使用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Tensor(張量是一個統稱,其中包括很多類型):
0階張量:標量、常數、0-D Tensor;1階張量:向量、1-D Tensor;2階張量:矩陣、2-D Tensor;……
import torch t = torch.Tensor([1, 2, 3]) print(t)
兩者之間可以相互轉化
import torch import numpy as np t1 = np.array(torch.Tensor([[1, 2, 3], [1, 2, 3]])) t2 = torch.Tensor(np.array([[1, 2, 3], [1, 2, 3]]))
運行結果:
torch.empty(x,y)
創建x行y列為空的tensor。
torch.ones([x, y])
創建x行y列全為1的tensor。
torch.zeros([x,y])
創建x行y列全為0的temsor。
zeros與empty的區別
后者的數據類型是不固定的。
torch.rand(x, y)
創建3行4列的隨機數,隨機數是0-1。
torch.randint(low, high, size)
創建一個size的tensor,隨機數為low到high之間。
torch.randn([x, y])
創建一個x行y列的tensor,隨機數的分布式均值為0,方差1。
item():
獲取tensor中的元素,注意只有
一個元素
的時候才可以用。
numpy():
轉化成
ndarray
類型。
size()
獲取tensor的
形狀
。
view()
可以傳參,表示獲取第幾個。若參數為-1,表示不確定,與另一個參數的乘積等于原始形狀的乘積。 例如:原始形狀為8,則
淺拷貝
,tensor的形狀改變
。view(-1,2)
?view(4, 2)
; 參數只有-1,表示一維。
dim()
獲取維度。
max()
獲取最大值。
t()
轉置。
transpose(x,y)
x,y是size里面返回的形狀相換。
permute()
傳入size()返回的形狀的順序。
transpose與permute的區別
前者傳入列即可相互交換;后者傳入列會根據傳入的順序來進行轉化,且需要傳入所有列數的索引。
取值[第一階, 第二階,……]
一個逗號隔開代表一個階乘冒號代表全取
賦值[第一階, 第二階,……]
直接賦值即可
tensor.dtype
獲取數據類型
設置數據類型
注意使用
Tensor()
不能指定數據類型。
type()
修改
數據類型。
torch.add(x, y)
將x和y
相加
。
直接相加
tensor.add()
使用add_()
可相加后直接保存在tensor中
tensor + 數值
CUDA
(Compute Unified Device Architecture),是NVIDIA推出的運算平臺。CUDATM是一種由NVIDIA推出的通用并行計算架構,該架構使GPU能夠解決復雜的計算問題。
torch.cuda這個模塊增加了對CUDA tensor的支持,能夠在cpu和gpu上使用相同的方法操作tensor通過.to
方法能夠把一個tensor轉移到另外一個設備(比如從CPU轉到GPU)
可以使用torch.cuda.is_available()
判斷電腦是否支持GPU
1.PyTorch是相當簡潔且高效快速的框架;2.設計追求最少的封裝;3.設計符合人類思維,它讓用戶盡可能地專注于實現自己的想法;4.與google的Tensorflow類似,FAIR的支持足以確保PyTorch獲得持續的開發更新;5.PyTorch作者親自維護的論壇 供用戶交流和求教問題6.入門簡單
關于“Python中Pytorch怎么使用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。