torch.gather用法笔记

gather的作用是在指定维度选择数据

import torch
#定义一个张量
x = torch.tensor([[1,2,3],[4,5,6]])
print(x)
#定义dim = 0 时的索引index0
index0 = torch.LongTensor([[0,1,1]])
print(index0)
y = torch.gather(x, 0, index0)
print(y)
#定义dim = 1 时的索引index1
index1 = torch.LongTensor([[0,1,1],[1,1,1]])
print(index1)
z = torch.gather(x, 1, index1)
print(z)

用法为torch.gather(input,dim,index)

input为定义的张量

tensor([[1, 2, 3],
        [4, 5, 6]])

dim为指定的维度,dim=0固定行,dim=1固定列,注意这里固定是index的维度,例如index0指定dim=0时,实际上index0是行维固定,列维待确定的索引

index0
(0,) (1,) (1,)

当执行gather后,index0的列维固定,此时index0为

index0
(0, 0) (1, 1) (1, 2)

在指定的张量x中按照index0索引选择数据,得到y

tensor([[1, 5, 6]])

index1指定dim=1时,实际上index1是列维固定,行维待确定的索引,此时此时index1为

index1
(,0),(,1),(,1)
(,1),(,1),(,1)

当执行gather后,index1的行维固定,此时index1为

index1
(0,0),(0,1),(0,1)
(1,1),(1,1),(1,1)

在指定的张量x中按照index1索引选择数据,得到z

tensor([[1, 2, 2],
        [5, 5, 5]])

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值