文档反馈

问题文档片段

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

提交类型
issue

有点复杂...

找人问问吧。

请选择提交类型

问题类型
规范和低错类

- 规范和低错类:

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

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

- 英文中包含中文字符。

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

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

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

易用性

- 易用性:

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

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

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

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

正确性

- 正确性:

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

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

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

- 代码片段错误。

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

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

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

风险提示

- 风险提示:

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

内容合规

- 内容合规:

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

- 内容侵权。

请选择问题类型

问题描述

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

mindspore.ops.unfold

mindspore.ops.unfold(input, kernel_size, dilation=1, padding=0, stride=1)[源代码]

从一个batch的输入Tensor中提取滑动局部块。

考虑一个batch的输入Tensor,其shape为 (N,C,) ,其中 N 是batch维度, C 是channel维度, 表示任意的空间维度。此操作将展平输入 x 空间维度内每个滑动的 kernel_size 大小的滑块为输出的3-D Tensor中的一列(如,最后一维),输出Tensor的shape为 (N,C×(kernel_size),L) , 其中 C×(kernel_size) 为每个滑块内值的总数量(一个滑块有 (kernel_size) 个空间位置, 每个位置都包含一个 C 通道的向量),共有 L 个这样的滑块:

L=dspatial_size[d]+2×pads[d]dilations[d]×(kernel_size[d]1)1strides[d]+1,

其中, spatial_size 由输入 x 的空间维度(上面的 )决定, d 遍历所有的空间维度。

因此,在最后一个维度(列维度)上 output 包含特定块内的所有值。

dilationpaddingstride 决定了滑块如何被取出。

警告

  • 该算子的输出为三维Tensor,其shape为 (N,C×(kernel_size),L)

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

参数:
  • input (Tensor) - 四维Tensor,支持的数据类型: float16、float32、float64、complex64和complex128。

  • kernel_size (Union[int, tuple[int], list[int]]) - 滑窗大小。如果是两个int,则分别为滑窗的高度和宽度;如果是一个int,则高度和宽度均为这个int值。是一个必要参数。

  • dilation (Union[int, tuple[int], list[int]],可选) - 窗口的空洞卷积的扩充率,如果是两个int,则分别作用于滑窗的高度和宽度;如果是一个int,则这个值作用于化窗的高度和宽度。默认值: 1

  • padding (Union[int, tuple[int], list[int]],可选) - 滑窗的隐式零填充量。为单个int或者包含一/二个整数的tuple/list。默认值: 0

    • 如果是一个int,则pad_height = pad_width。

    • 如果是两个int,则pad_height = padding[0], pad_width = padding[1]。

  • stride (Union[int, tuple[int], list[int]],可选) - 空间维度上滑动的步长,如果是两个int,则分别为滑窗的高和宽方向上的步长;如果是一个int,则高和宽方向上的步长均为这个int值。默认值: 1

返回:

Tensor,数据类型与 input 相同,其shape如上所述。

异常:
  • TypeError - 如果 kernel_sizestridedilationpadding 的数据类型不是int、tuple或者list。

  • ValueError - 如果 kernel_sizedilationstride 包含元素的值小于等于0或者元素个数大于 2

  • ValueError - 如果 padding 包含元素的值小于零。

支持平台:

Ascend GPU CPU

样例:

>>> import mindspore
>>> import numpy as np
>>> from mindspore import Tensor, ops
>>> x = Tensor(np.random.rand(4, 4, 32, 32), mindspore.float64)
>>> output = ops.unfold(x, kernel_size=3, dilation=1, stride=1)
>>> print(output.shape)
(4, 36, 900)