You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

mindspore.ops.ScatterNd.rst 1.7 kB

1234567891011121314151617181920212223242526272829303132333435
  1. mindspore.ops.ScatterNd
  2. ========================
  3. .. py:class:: mindspore.ops.ScatterNd
  4. 根据指定的索引将更新值散布到新Tensor上。
  5. 使用给定的 `shape` 创建一个空Tensor,并将 `updates` 的值通过索引来设置空Tensor的值。
  6. 空Tensor的秩为P,而 `indices` 的秩为Q, `Q >= 2` 。
  7. `indices` 的shape为 :math:`(i_0, i_1, ..., i_{Q-2}, N)` , `N <= P` 。
  8. `indices` 的最后一个维度(长度为 `N` )表示沿着空Tensor的 `N` 个维度进行切片。
  9. `updates` 表示秩为 `Q-1+P-N` 的Tensor,shape为 :math:`(i_0, i_1, ..., i_{Q-2}, shape_N, ..., shape_{P-1})` 。
  10. 在秩为3的第一个维度中插入两个新值矩阵的计算过程如下图所示:
  11. .. image:: ScatterNd.png
  12. **输入:**
  13. - **indices** (Tensor) - 指定新Tensor中散布的索引,数据类型为int32或int64。索引的秩须至少为2,并且 `indices_shape[-1] <= len(shape)` 。
  14. - **updates** (Tensor) - 指定更新Tensor,shape为 `indices_shape[:-1] + shape[indices_shape[-1]:]` 。
  15. - **shape** (tuple[int]) - 指定输出Tensor的shape,数据类型与索引相同。 `shape` 为 :math:`(x_1, x_2, ..., x_R)` 且 `shape` 的长度大于或等于2。换句话说, `shape` 至少是 :math:`(x_1, x_2)` ,且 `shape` 中的任何元素的值都必须大于等于1。也就是说, :math:`x_1` >= 1, :math:`x_2` >= 1。
  16. **输出:**
  17. Tensor,更新后的Tensor,数据类型与输入 `update` 相同,shape与输入 `shape` 相同。
  18. **异常:**
  19. - **TypeError** - `shape` 不是tuple。
  20. - **ValueError** - `shape` 的任何元素小于1。