mindspore.mint.nn.functional.max_unpool2d

查看源文件
mindspore.mint.nn.functional.max_unpool2d(input, indices, kernel_size, stride=None, padding=0, output_size=None)[源代码]

max_pool2d 的逆过程。

max_unpool2d 在计算过程中,保留最大值位置的元素,并将非最大值位置元素设置为0。支持的输入数据格式为 (N,C,Hin,Win)(C,Hin,Win) ,输出数据的格式为 (N,C,Hout,Wout)(C,Hout,Wout) ,计算公式如下:

Hout=(Hin1)×stride[0]2×padding[0]+kernel_size[0]Wout=(Win1)×stride[1]2×padding[1]+kernel_size[1]

警告

这是一个实验性API,后续可能修改或删除。

参数:
  • input (Tensor) - 待求逆的Tensor。shape为 (N,C,Hin,Win)(C,Hin,Win)

  • indices (Tensor) - 最大值的索引。shape必须与输入 input 相同。取值范围需满足 [0,Hin×Win1] 。数据类型必须是int32或int64。

  • kernel_size (Union[int, tuple[int]]) - 池化核尺寸大小。int类型表示池化核的长宽相同。tuple类型中的两个值分别代表池化核的长和宽。

  • stride (Union[int, tuple[int]],可选) - 池化操作的移动步长,int类型表示长宽方向的移动步长相同。tuple中的两个值分别代表长宽方向移动的步长。默认值: None ,表示移动步长为 kernel_size

  • padding (Union[int, tuple[int]],可选) - 填充值。默认值: 0 。若为int类型,则长宽方向的填充大小相同,均为 padding 。若为tuple类型,则tuple中的两个值分别代表长宽方向填充的大小。

  • output_size (tuple[int],可选) - 输出shape。默认值: None 。如果output_size为(),那么输出shape根据 kernel_sizestridepadding 计算得出。如果output_size不为(),那么 output_size 必须满足格式 (N,C,H,W)(C,H,W)(H,W) ,取值范围需满足:[(N,C,Houtstride[0],Woutstride[1]),(N,C,Hout+stride[0],Wout+stride[1])]

返回:

shape为 (N,C,Hout,Wout)(C,Hout,Wout) 的Tensor,数据类型与输入 input 相同。

异常:
  • TypeError - inputindices 的数据类型不支持。

  • TypeError - kernel_sizestridepadding 既不是整数也不是tuple。

  • ValueError - stridepaddingkernel_size 的值不是非负的。

  • ValueError - inputindices 的shape不一致。

  • ValueError - input 的长度不为3或4。

  • ValueError - output_size 的类型不是tuple。

  • ValueError - output_size 的取值与根据 kernel_sizestridepadding 计算得到的结果差距太大。

支持平台:

Ascend

样例:

>>> import numpy as np
>>> from mindspore import Tensor, mint
>>> input = Tensor(np.array([[[[0, 1], [8, 9]]]]).astype(np.float32))
>>> indices = Tensor(np.array([[[[0, 1], [2, 3]]]]).astype(np.int64))
>>> output = mint.nn.functional.max_unpool2d(input, indices, 1, stride=1, padding=0)
>>> print(output.asnumpy())
[[[[0. 1.]
   [8. 9.]]]]