在PyTorch 中,torch.Tensor
是主要的tensor类,所有的tensor都是torch.Tensor
的实例。torch.Tensor
是torch.FloatTensor
的别名。
而torch.tensor
是一个函数,返回的是一个tensor,在PyTorch官方文档中,描述如下:
torch.tensor(data, dtype=None, device=None, requires_grad=False) → Tensor
Constructs a tensor with data.
所以需要注意的一点是:
torch.Tensor(data)
是将输入的data转化torch.FloatTensor
torch.tensor(data)
:(当你未指定dype
的类型时)将data转化为torch.FloatTensor
、torch.LongTensor
、torch.DoubleTensor
等类型,转化类型依据于data的类型或者dtype
的值使用如下语句:tensor_without_data = torch.Tensor()
可以创建一个空的FloatTensor
,而当你使用tensor_without_data = torch.tensor()
时候则会报错:
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-12-ebc3ceaa76d2> in <module>()
----> 1 torch.tensor()
TypeError: tensor() missing 1 required positional arguments: "data"
tensor_without_data = torch.Tensor() # tensor([])
tensor_without_data = torch.tensor(()) # tensor([])
tensor_without_data = torch.empty([]) # tensor(0.)
所以torch.Tensor
应该说是同时具有torch.tensor
和torch.empty
的功能,但是使用torch.Tensor
可能会使你的代码confusing,所以最好还是使用torch.tensor
和torch.empty
,而不是torch.Tensor
。