Pytorch——tensor.expand_as()函数

行人重识别Relation-Aware Global Attention的部分代码。

			W_ys = self.W_spatial(ys) # W_ys的维度是[8, 1, 64, 32]  是空间位置特征权重 
			# print(W_ys.shape)
			# x的维度是[8, 256, 64, 32] 
			if not self.use_channel:
				out = F.sigmoid(W_ys.expand_as(x)) * x # 位置特征,不同特征图,位置相同的
				return out
			else:   # 走的这一路
				x = F.sigmoid(W_ys.expand_as(x)) * x
			#print(x.shape) # 8 256 64 32

其中W_ys.expand_as(x)是为了把W_ys的维度[8, 1, 64, 32]扩展为和x一样的维度[8, 256, 64, 32] 。
简单例子如下:
1、

import torch
x = torch.tensor([[1], [2], [3]])
print('xsize:',x.size())
print('x:',x)

输出为:

xsize: torch.Size([3, 1])
x: tensor([[1],
        [2],
        [3]])

2、

x_expand=x.expand(3,4)
print('x_expand:',x_expand)

输出为:

x_expand: tensor([[1, 1, 1, 1],
        [2, 2, 2, 2],
        [3, 3, 3, 3]])

3、

x_expand=x.expand(-1,4)  # -1 means not changing the size of that dimension
print('x_expand:',x_expand)

输出为:

x_expand: tensor([[1, 1, 1, 1],
        [2, 2, 2, 2],
        [3, 3, 3, 3]])

4、

x_expand_as=x.expand_as(x_expand)
print('x_expand_as:',x_expand_as)

输出为:

x_expand_as: tensor([[1, 1, 1, 1],
        [2, 2, 2, 2],
        [3, 3, 3, 3]])
  • 另外,expand()函数括号里面为变形后的size大小,而且原来的tensor和tensor.expand()是不共享内存的。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值