mindspore.ops.ScatterNonAliasingAdd

class mindspore.ops.ScatterNonAliasingAdd[源代码]

使用给定值通过加法操作和输入索引来更新Tensor值。此操作在更新完成后输出 input_x ,这有利于更加方便地使用更新后的值。

输入的 input_xupdates 遵循隐式类型转换规则,以确保数据类型一致。如果它们具有不同的数据类型,则低精度数据类型将转换为高精度数据类型。当需要转换Parameter的数据类型时,则会抛出RuntimeError异常。

输入:
  • input_x (Parameter) - ScatterNonAliasingAdd的输入,任意维度的Parameter。其数据类型为float16、float32或int32。

  • indices (Tensor) - 指定加法操作的索引。其数据类型为mindspore.int32。

  • updates (Tensor) - 指定与 input_x 相加操作的Tensor。其数据类型与 input_x 相同,shape为 indices.shape[:-1] + x.shape[indices.shape[-1]:]

输出:

Parameter,表示更新后的 input_x

异常:
  • TypeError - indices 的数据类型不是int32。

  • TypeError - input_x 的数据类型不是float16、float32或int32。

  • ValueError - updates 的shape不是 indices.shape[:-1] + x.shape[indices.shape[-1]:]

  • RuntimeError - 当 input_xupdates 类型不一致,需要进行类型转换时,如果 updates 不支持转成参数 input_x 需要的数据类型,就会报错。

支持平台:

Ascend

样例:

>>> input_x = Parameter(Tensor(np.array([1, 2, 3, 4, 5, 6, 7, 8]), mindspore.float32), name="x")
>>> indices = Tensor(np.array([[2], [4], [1], [7]]), mindspore.int32)
>>> updates = Tensor(np.array([6, 7, 8, 9]), mindspore.float32)
>>> scatter_non_aliasing_add = ops.ScatterNonAliasingAdd()
>>> output = scatter_non_aliasing_add(input_x, indices, updates)
>>> print(output)
[ 1. 10.  9.  4. 12.  6.  7. 17.]