首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在pytorch中,我如何对一些元素求和,并得到较小形状的张量?

在pytorch中,我如何对一些元素求和,并得到较小形状的张量?
EN

Stack Overflow用户
提问于 2020-03-20 13:56:05
回答 1查看 325关注 0票数 2

具体地说,我有一个298x160x160维度的张量( 298帧中的面),我需要对最后两个维度中的每个4x4元素求和,这样我就可以得到298x40x40张量。

我怎样才能做到这一点呢?

EN

回答 1

Stack Overflow用户

发布于 2020-03-20 21:01:43

可以创建具有单个4x4通道的卷积层,并将其权重设置为1,步幅为4 (also see Conv2D doc):

代码语言:javascript
复制
a = torch.ones((298,160,160))
# add a dimension for the channels. Conv2D expects the input to be : (N,C,H,W)
# where N=number of samples, C=number of channels, H=height, W=width
a = a.unsqueeze(1)
a.shape

Out: torch.Size([298, 1, 160, 160])

代码语言:javascript
复制
with torch.no_grad(): # I assume you don't need to backprop, otherwise remove this check
    m = torch.nn.Conv2d(in_channels=1, out_channels=1, kernel_size=4,stride=4,bias=False)
    # set the kernel values to 1
    m.weight.data = m.weight.data * 0. + 1.
# apply the kernel and squeeze the channel dim out again
res = m(a).squeeze()
res.shape

Out: torch.Size([298, 40, 40])

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60769227

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档