文档反馈

问题文档片段

问题文档片段包含公式时,显示为空格。

提交类型
issue

有点复杂...

找人问问吧。

请选择提交类型

问题类型
规范和低错类

- 规范和低错类:

- 错别字或拼写错误,标点符号使用错误、公式错误或显示异常。

- 链接错误、空单元格、格式错误。

- 英文中包含中文字符。

- 界面和描述不一致,但不影响操作。

- 表述不通顺,但不影响理解。

- 版本号不匹配:如软件包名称、界面版本号。

易用性

- 易用性:

- 关键步骤错误或缺失,无法指导用户完成任务。

- 缺少主要功能描述、关键词解释、必要前提条件、注意事项等。

- 描述内容存在歧义指代不明、上下文矛盾。

- 逻辑不清晰,该分类、分项、分步骤的没有给出。

正确性

- 正确性:

- 技术原理、功能、支持平台、参数类型、异常报错等描述和软件实现不一致。

- 原理图、架构图等存在错误。

- 命令、命令参数等错误。

- 代码片段错误。

- 命令无法完成对应功能。

- 界面错误,无法指导操作。

- 代码样例运行报错、运行结果不符。

风险提示

- 风险提示:

- 对重要数据或系统存在风险的操作,缺少安全提示。

内容合规

- 内容合规:

- 违反法律法规,涉及政治、领土主权等敏感词。

- 内容侵权。

请选择问题类型

问题描述

点击输入详细问题描述,以帮助我们快速定位问题。

mindspore.ops.max_unpool1d

mindspore.ops.max_unpool1d(x, indices, kernel_size, stride=None, padding=0, output_size=None)[源代码]

max_pool1d 的逆过程。

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

Hout=(Hin1)×stride[0]2×padding[0]+kernel_size[0]
参数:
  • x (Tensor) - 待求逆的Tensor。shape为 (N,C,Hin)(C,Hin)

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

  • kernel_size (Union[int, tuple[int]]) - 池化核尺寸大小。

  • stride (Union[int, tuple[int]]) - 池化操作的移动步长,若取值为 '0', '(0)' 或 Nonestride 值与 kernel_size 相同。默认值: None ,表示移动步长为 kernel_size

  • padding (Union[int, tuple[int]]) - 填充值。默认值: 0

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

返回:

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

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

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

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

  • ValueError - xindices 的shape不一致。

  • ValueError - x 的长度不是2或3。

  • ValueError - output_size 的类型不是tuple。

  • ValueError - output_size 的长度不为0、2或3。

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

支持平台:

Ascend GPU CPU

样例:

>>> import numpy as np
>>> from mindspore import Tensor, ops
>>> x = Tensor(np.array([[2, 4, 6, 8]]).astype(np.float32))
>>> indices = Tensor(np.array([[1, 3, 5, 7]]).astype(np.int64))
>>> output = ops.max_unpool1d(x, indices, kernel_size =2, stride=2, padding=0)
>>> print(output.asnumpy())
[[0. 2. 0. 4. 0. 6. 0. 8.]]