前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >pytorch的python API略读--tensor(六)

pytorch的python API略读--tensor(六)

作者头像
用户9875047
发布2022-07-04 14:04:53
2510
发布2022-07-04 14:04:53
举报
文章被收录于专栏:机器视觉全栈er机器视觉全栈er

2.1.5 变换

变换的概念更加宽泛一点,我们这里指索引、分和合以外的tensor操作。

torch.gather:沿着某个维度对输入tensor进行变换,用法如下:

代码语言:javascript
复制
torch.gather(input, dim, index, *, sparse_grad=False, out=None)

下面举个例子说明下:

代码语言:javascript
复制
>>> cvtutorials = torch.randn(2, 2)
>>> cvtutorials
tensor([[-0.3918, -0.3979],
        [-0.5268, -0.7679]])
>>> torch.gather(cvtutorials, 1, torch.tensor([[1, 0], [0, 1]]))
tensor([[-0.3979, -0.3918],
        [-0.5268, -0.7679]])
>>> torch.gather(cvtutorials, 0, torch.tensor([[1, 0], [0, 1]]))
tensor([[-0.5268, -0.3979],
        [-0.3918, -0.7679]])

torch.permute:返回输入tensor的一个维度层次的置换,不知道置换的概念,可以搜索下群论中的置换群的定义及置换的记号。用法如下:

代码语言:javascript
复制
torch.permute(input, dims)

举个例子:

代码语言:javascript
复制
>>> cvtutorials = torch.randn(3, 4, 5)
>>> cvtutorials.size()
torch.Size([3, 4, 5])
>>> torch.permute(cvtutorials, (2, 1, 0)).size()
torch.Size([5, 4, 3])

torch.shape: 对输入tensor的shape进行变换,这个函数在深度学习编程中经常用到,用法如下:

代码语言:javascript
复制
>>> cvtutorials = torch.randn(3, 4)
>>> torch.reshape(cvtutorials, (2, 6))
tensor([[ 0.3349, -1.6753, -1.9647, -1.7345, -1.5996,  0.4831],
        [ 1.3172,  0.4480, -0.4297, -0.5676,  1.2655, -0.2147]])

torch.transpose: 对tensor进行变换,如果是二维tensor,也就是矩阵中的转置,用法如下:

代码语言:javascript
复制
torch.transpose(input, dim0, dim1)

举个例子如下:

代码语言:javascript
复制
>>> cvtutorials
tensor([[ 0.0692,  0.8415,  1.2454, -1.8095],
        [ 0.4224, -0.3615, -1.2436, -0.8849]])
>>> torch.transpose(cvtutorials, 0, 1)
tensor([[ 0.0692,  0.4224],
        [ 0.8415, -0.3615],
        [ 1.2454, -1.2436],
        [-1.8095, -0.8849]])

torch.tile:通过重复输入tensor的元素构造新的元素,类似matlab中的repmat,用法如下:

代码语言:javascript
复制
torch.tile(input, dims)

举个例子说明如下:

代码语言:javascript
复制
>>> cvtutorials = torch.randn(2, 4)
>>> cvtutorials
tensor([[-1.7618,  0.8413,  1.5977,  1.3316],
        [ 1.1877, -0.3684, -0.0081, -0.0878]])
>>> torch.tile(cvtutorials, (1, 2))
tensor([[-1.7618,  0.8413,  1.5977,  1.3316, -1.7618,  0.8413,  1.5977,  1.3316],
        [ 1.1877, -0.3684, -0.0081, -0.0878,  1.1877, -0.3684, -0.0081, -0.0878]])
>>> torch.tile(cvtutorials, (2, 1))
tensor([[-1.7618,  0.8413,  1.5977,  1.3316],
        [ 1.1877, -0.3684, -0.0081, -0.0878],
        [-1.7618,  0.8413,  1.5977,  1.3316],
        [ 1.1877, -0.3684, -0.0081, -0.0878]])
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-03-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 机器视觉全栈er 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 2.1.5 变换
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档