当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Python PyTorch MaxUnpool2d用法及代码示例


本文简要介绍python语言中 torch.nn.MaxUnpool2d 的用法。

用法:

class torch.nn.MaxUnpool2d(kernel_size, stride=None, padding=0)

参数

  • kernel_size(int或者tuple) -最大池化窗口的大小。

  • stride(int或者tuple) -最大池化窗口的步幅。默认设置为kernel_size

  • padding(int或者tuple) -添加到输入的填充

计算 MaxPool2d 的部分逆。

MaxPool2d 不是完全可逆的,因为非最大值会丢失。

MaxUnpool2d MaxPool2d 的输出(包括最大值的索引)作为输入,并计算部分逆,其中所有非最大值都设置为零。

注意

MaxPool2d 可以将多个输入大小映射到相同的输出大小。因此,反演过程可能会变得模棱两可。为了适应这种情况,您可以在转发调用中提供所需的输出大小作为附加参数output_size。请参阅下面的输入和示例。

输入:
  • input : 要反转的输入张量

  • indices : MaxPool2d 给出的索引

  • output_size(可选):目标输出大小

形状:
  • 输入:

  • 输出: ,其中

    或由调用运算符中的output_size 给出

例子:

>>> pool = nn.MaxPool2d(2, stride=2, return_indices=True)
>>> unpool = nn.MaxUnpool2d(2, stride=2)
>>> input = torch.tensor([[[[ 1.,  2,  3,  4],
                            [ 5,  6,  7,  8],
                            [ 9, 10, 11, 12],
                            [13, 14, 15, 16]]]])
>>> output, indices = pool(input)
>>> unpool(output, indices)
tensor([[[[  0.,   0.,   0.,   0.],
          [  0.,   6.,   0.,   8.],
          [  0.,   0.,   0.,   0.],
          [  0.,  14.,   0.,  16.]]]])

>>> # specify a different output size than input size
>>> unpool(output, indices, output_size=torch.Size([1, 1, 5, 5]))
tensor([[[[  0.,   0.,   0.,   0.,   0.],
          [  6.,   0.,   8.,   0.,   0.],
          [  0.,   0.,   0.,  14.,   0.],
          [ 16.,   0.,   0.,   0.,   0.],
          [  0.,   0.,   0.,   0.,   0.]]]])

相关用法


注:本文由纯净天空筛选整理自pytorch.org大神的英文原创作品 torch.nn.MaxUnpool2d。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。