MaxUnpool1d¶
- class torch.nn.MaxUnpool1d(kernel_size, stride=None, padding=0)[source][source]¶
计算
MaxPool1d
的部分逆操作。MaxPool1d
不是完全可逆的,因为非最大值会丢失。MaxUnpool1d
接收MaxPool1d
的输出作为输入,包括最大值的索引,并计算部分逆操作,其中所有非最大值都设为零。注意
当输入索引存在重复值时,此操作可能会出现非确定性行为。更多信息请参阅 https://github.com/pytorch/pytorch/issues/80827 和可重现性。
注意
MaxPool1d
可以将几种输入尺寸映射到相同的输出尺寸。因此,逆向过程可能会变得模糊不清。为了解决这个问题,可以在 forward 调用中提供所需的输出尺寸作为附加参数output_size
。请参见下面的 输入 和 示例。- 参数
- 输入
input: 要反转的输入 Tensor
indices: 由
MaxPool1d
输出的索引output_size (可选): 目标输出尺寸
- 形状
输入: 或 。(其中 N 是 batch size,C 是通道数, 是输入长度)
输出: 或 ,其中
或由调用操作符中的
output_size
给出
示例
>>> pool = nn.MaxPool1d(2, stride=2, return_indices=True) >>> unpool = nn.MaxUnpool1d(2, stride=2) >>> input = torch.tensor([[[1., 2, 3, 4, 5, 6, 7, 8]]]) >>> output, indices = pool(input) >>> unpool(output, indices) tensor([[[ 0., 2., 0., 4., 0., 6., 0., 8.]]]) >>> # Example showcasing the use of output_size >>> input = torch.tensor([[[1., 2, 3, 4, 5, 6, 7, 8, 9]]]) >>> output, indices = pool(input) >>> unpool(output, indices, output_size=input.size()) tensor([[[ 0., 2., 0., 4., 0., 6., 0., 8., 0.]]]) >>> unpool(output, indices) tensor([[[ 0., 2., 0., 4., 0., 6., 0., 8.]]])