【发布时间】:2020-04-09 06:52:23
【问题描述】:
我有如下所示的 PyTorch 网络架构。它接受大小为 16x8x2048 的输入,并给出大小为 256x128x3 的输出。我有一个特征图,我想在下面架构中的每个上采样层之后沿着通道维度附加。在附加之前,我会将特征图缩放到适当的分辨率。如何将这些特征图附加到网络的中间层?
model = []
model += [Conv2dBlock(2048, 256, 3, 1, 1, norm='bn', activation=activ, pad_type=pad_type)]
model += [nn.Upsample(scale_factor=2, mode='bilinear')]
model += [Conv2dBlock(256, 128, 3, 1, 1, norm='bn', activation=activ, pad_type=pad_type)]
model += [nn.Upsample(scale_factor=2, mode='bilinear')]
model += [Conv2dBlock(128, 64, 3, 1, 1, norm='bn', activation=activ, pad_type=pad_type)]
model += [nn.Upsample(scale_factor=2, mode='bilinear')]
model += [Conv2dBlock(64, 32, 3, 1, 1, norm='bn', activation=activ, pad_type=pad_type)]
model += [nn.Upsample(scale_factor=2, mode='bilinear')]
model += [Conv2dBlock(32, 32, 3, 1, 1, norm='bn', activation=activ, pad_type=pad_type)]
model += [Conv2dBlock(32, 3, 3, 1, 1, norm='none', activation=activ, pad_type=pad_type)]
model = nn.Sequential(*model)
【问题讨论】:
-
像这样定义模型并不是很好的做法,主要是因为您无法像现在想要的那样定义动态输入行为。您必须定义一个实际的 nn.Module 类网络,然后以您想要的方式编写前向函数:您在每个上采样的输出上调用 torch.cat 以添加额外的特征图。查看如何定义跳过连接。
-
谢谢!这种方法奏效了。
标签: python computer-vision pytorch conv-neural-network