输出:
tensor([[[1., 2., 3.], [4., 5., 6.], [7., 8., 9.]]]) torch.Size([1, 3, 3])改变tensor的形状
view() 的具体理解请见文章:pytorch中x = x.view(x.size(0), -1) 的理解
b = a.view(3,-1) print(b) print(b.size())输出
tensor([[1., 2., 3.], [4., 5., 6.], [7., 8., 9.]]) torch.Size([3, 3])或者使用view把a变换为和permute() 一样的形状,请注意tensor的内容是不一样的
d = a.view(3,1,3) print(d) print(d.size())输出:
tensor([[[1., 2., 3.]], [[4., 5., 6.]], [[7., 8., 9.]]]) torch.Size([3, 1, 3])用于维度换位
c= a.permute(2,0,1) print(c) print(c.size())输出:
tensor([[[1., 4., 7.]], [[2., 5., 8.]], [[3., 6., 9.]]]) torch.Size([3, 1, 3])有些tensor并不是占用一整块内存,而是由不同的数据块组成。
contiguous()函数的作用:把tensor变成在内存中连续分布的形式。
参考:https://blog.csdn.net/u014221266/article/details/80143212
另外:
numpy中的transpose() 函数是可以改变高维数组的形状
img_ = img[:,:,::-1].transpose((2,0,1))参考文章:一文掌握torch.squeeze() 和torch.unsqueeze()的用法
torch.squeeze() 这个函数主要对数据的维度进行压缩,去掉维数为1的的维度,默认是将a中所有为1的维度删掉。也可以通过dim指定位置,删掉指定位置的维数为1的维度。
相反
torch.unsqueeze() 这个函数主要是对数据维度进行扩充。需要通过dim指定位置,给指定位置加上维数为1的维度。
