下面参数中的省略号代表dtype、requires_grad等常规参数。
一、
torch.tensor(data, dtype=None, device=None, requires_grad=False, pin_memory=False) → Tensor
1、用data创建一个tensor
2、torch.tensor会从data出复制数据,意味着生成的tensor不会和data共享内存(改变data并不会改变tensor)
import torch
device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')
x = torch.tensor([1.,2], dtype=torch.float64, device=device,requires_grad=True)
x
tensor([ 1., 2.], dtype=torch.float64, device='cuda:0')
二、
torch.sparse_coo_tensor(indices, values, size=None, dtype=None, device=None, requires_grad=False) → Tensor :创建一个稀疏tensor,格式为COO类型
COO类型表示给出非零元素的坐标形式
indices = torch.tensor([[0, 1, 1], [2, 0, 2]])
values = torch.tensor([3, 4, 5], dtype=torch.float32)
x = torch.sparse_coo_tensor(i, v, [2, 4])
x
torch.sparse.FloatTensor of size (2,4) with indices:
tensor([[ 0, 1, 1],
[ 2, 0, 2]])
and values:
tensor([ 3., 4., 5.])
三、
torch.as_tensor(data, dtype=None,device=None)->Tensor : 为data生成tensor
如果data已经是tensor,且dtype和device与参数相同,则生成的tensor会和data共享内存。如果data是ndarray,且dtype对应,devices为cpu,则同样共享内存。其他情况则不共享内存。
import torch
import numpy
a = numpy.array([1, 2, 3])
t = torch.as_tensor(a)
四、
torch.from_numpyy(ndarray) -> tensor
将numpy.ndarray数据转换为tensor,其tensor与ndarry共享内存
import torch
import numpy
x = numpy.array([1,2,3])
y = torch.from_numpy(x)
print(y)
y[0]=100
print(x)
tensor([ 1, 2, 3])
[100 2 3]
五、
torch.zeros(*sizes, out=None, dtype=None …) -> Tensor
torch.ones同理
生成一个size大小的0tensor
import torch
torch.zeros(2,3)
tensor([[ 0., 0., 0.],
[ 0., 0., 0.]])
六、
torch.zeros_like(input, dtype=None, …) -> Tensor
torch.ones_like同理
生成和input形状一样的0tensor
import torch
x = torch.tensor([2,3])
y = torch.zeros_like(x)
y
tensor([ 0, 0])
七、
torch.arange(start=0, end, step=1,…) ->tensor
从start开始,每step步生成一个数值,直到end
import torch
x = torch.arange(start=2, end=7, step=1.5)
x
tensor([ 2.0000, 3.5000, 5.0000, 6.5000])
八、
torch.linspace(start,end,steps=100,…)->tensor
在start到end之间生成均匀分布的steps个数
import torch
x = torch.linspace(2,7,5)
x
tensor([ 2.0000, 3.2500, 4.5000, 5.7500, 7.0000])
九、
torch.eye(n,m=None,…)
生成形状为(n,m),对角线为1,其余为0的矩阵。m默认等于n
import torch
x = torch.eye(3)
print(x)
y = torch.eye(3,2)
print(y)
tensor([[ 1., 0., 0.],
[ 0., 1., 0.],
[ 0., 0., 1.]])
tensor([[ 1., 0.],
[ 0., 1.],
[ 0., 0.]])
十、
torch.empty(*sizes, …)->tensor : 生成size大小的未经未经过初始化的数据。
torch.empty_like与torch.ones_like类似
import torch
x = torch.empty(2,3)
x
tensor([[ 0.0667, 0.0000, 3.1263],
[ 0.0000, 0.0000, 0.0000]])
十一、
torch.full(size, fill_value, …) -> Tensor :生成size大小以fill_value填充的tensor
torch.full_like与torch.ones_like同理
import torch
x = torch.full((2,3),0.5)
x
tensor([[ 0.5000, 0.5000, 0.5000],
[ 0.5000, 0.5000, 0.5000]])