数据、代码等相关资料来源于b站日月光华老师视频,此博客作为学习记录。
pytorch的最基本操作对象是张量,它表示一个多维矩阵。张量类似于numpy的ndarrays,可在GPU上使用以加速计算。
张量是向量和矩阵基础上的推广,可以将标量看作零阶张量,向量看作一阶张量,矩阵看作二阶张量,以及更高维的数据。
张量和numpy的ndarray的数组是共享相同底层内存,无需复制数据。
创建一个张量:
import torch
import numpy as np
t = torch.tensor([1,2,3])
print(t)
print(t.dtype)
其数据类型可用属性.dtype得到:
torch.tensor是根据数据自动确定数据类型的,如:
t = torch.FloatTensor([1.1, 2.3 , 3.6])
print(t.dtype)
其结果为:
改变数据类型为Float:
t = torch.FloatTensor([1,2,3])
print(t.dtype)
结果为:
相应的还有torch.LongTensor,其生成数据类型为int64.
创建ndarray:
np_array = np.arange(12).reshape(3,4)
打印出来:
对该数据进行torch.from_numpy,就成为了tensor:
tt = torch.from_numpy(np_array)
# 创建0~1之间均匀分布的随机数,其参数为数据的形状
p = torch.rand(2, 3) # 创建一个2×3的tensor
print(p)
# 创建0~1之间服从标准正态分布的随机数
pp = torch.randn(2, 3) # 2×3大小
print(pp)
print(pp.shape)
a = torch.zeros(2,3)
a = torch.ones(3, 2)
创建与某个tensor形状、数据类型一样的tensor可用like:
s = torch.rand(2,3)
x = torch.zeros_like(s) # 跟s形状一样,全0的tensor
s = torch.rand(2,3)
x = torch.rand_like(s) # 跟s形状一样、0~1之间均匀分布的随机数tensor
tensor除了shape属性可以得到其形状,还有size属性.
tt = torch.from_numpy(np_array)
print(tt.shape)
print(tt.size())
print(tt.size(0)) # 返回第1个维度大小
print(tt.size(1)) # 返回第2个维度大小
device属性:
import torch
import numpy as np
np_array = np.arange(12).reshape(3, 4)
t = torch.from_numpy(np_array)
print(t.device)
# 得到t的device,在cpu上运行则显示cpu,在gpu上则显示cuda
运行结果:
将tensor如何由cpu转移到gpu运行呢?
首先,先看看自己的gpu是否可用:
# 判断当前gpu是否可用
print(torch.cuda.is_available())
if torch.cuda.is_available():
t = t.to('cuda')