當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


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。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。