mindspore.ops.ScatterNd ======================== .. py:class:: mindspore.ops.ScatterNd 根据指定的索引将更新值散布到新Tensor上。 使用给定的 `shape` 创建一个空Tensor,并将 `updates` 的值通过索引来设置空Tensor的值。 空Tensor的秩为P,而 `indices` 的秩为Q, `Q >= 2` 。 `indices` 的shape为 :math:`(i_0, i_1, ..., i_{Q-2}, N)` , `N <= P` 。 `indices` 的最后一个维度(长度为 `N` )表示沿着空Tensor的 `N` 个维度进行切片。 `updates` 表示秩为 `Q-1+P-N` 的Tensor,shape为 :math:`(i_0, i_1, ..., i_{Q-2}, shape_N, ..., shape_{P-1})` 。 在秩为3的第一个维度中插入两个新值矩阵的计算过程如下图所示: .. image:: ScatterNd.png **输入:** - **indices** (Tensor) - 指定新Tensor中散布的索引,数据类型为int32或int64。索引的秩须至少为2,并且 `indices_shape[-1] <= len(shape)` 。 - **updates** (Tensor) - 指定更新Tensor,shape为 `indices_shape[:-1] + shape[indices_shape[-1]:]` 。 - **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。 **输出:** Tensor,更新后的Tensor,数据类型与输入 `update` 相同,shape与输入 `shape` 相同。 **异常:** - **TypeError** - `shape` 不是tuple。 - **ValueError** - `shape` 的任何元素小于1。