mindspore.Tensor.tile

查看源文件
mindspore.Tensor.tile(dims)

按照给定的次数复制输入Tensor。

说明

在Ascend平台上, dims 参数的个数不大于8,当前不支持超过4个维度同时做repeat的场景。

参数:
  • dims (tuple[int]) - 指定复制次数的参数,参数类型为tuple,数据类型为整数。如 \((y_1, y_2, ..., y_S)\) 。 只支持常量值。

返回:

Tensor,具有与 self 相同的数据类型。假设 dims 的长度为 dself 的维度为 self.dimself 的shape为 \((x_1, x_2, ..., x_S)\)

  • 如果 self.dim = d ,将其相应位置的shape相乘,输出的shape为 \((x_1*y_1, x_2*y_2, ..., x_S*y_S)\)

  • 如果 self.dim < d ,在 self 的shape的前面填充1,直到它们的长度一致。例如将 self 的shape设置为 \((1, ..., x_1, x_2, ..., x_S)\) ,然后可以将其相应位置的shape相乘,输出的shape为 \((1*y_1, ..., x_R*y_R, x_S*y_S)\)

  • 如果 self.dim > d ,在 dims 的前面填充1,直到它们的长度一致。例如将 dims 设置为 \((1, ..., y_1, y_2, ..., y_S)\) ,然后可以将其相应位置的shape相乘,输出的shape为 \((x_1*1, ..., x_R*y_R, x_S*y_S)\)

异常:
  • TypeError - dims 不是tuple或者其元素并非全部是int。

  • ValueError - dims 的元素并非全部大于或等于0。

支持平台:

Ascend GPU CPU

样例:

>>> import mindspore
>>> import numpy as np
>>> from mindspore import Tensor
>>> input = Tensor(np.array([[1, 2], [3, 4]]), mindspore.float32)
>>> dims = (2, 3)
>>> output = input.tile(dims)
>>> print(output)
[[1.  2.  1.  2.  1.  2.]
 [3.  4.  3.  4.  3.  4.]
 [1.  2.  1.  2.  1.  2.]
 [3.  4.  3.  4.  3.  4.]]
>>> dims = (2, 3, 2)
>>> output = input.tile(dims)
>>> print(output)
[[[1. 2. 1. 2.]
  [3. 4. 3. 4.]
  [1. 2. 1. 2.]
  [3. 4. 3. 4.]
  [1. 2. 1. 2.]
  [3. 4. 3. 4.]]
 [[1. 2. 1. 2.]
  [3. 4. 3. 4.]
  [1. 2. 1. 2.]
  [3. 4. 3. 4.]
  [1. 2. 1. 2.]
  [3. 4. 3. 4.]]]
mindspore.Tensor.tile(reps)

详情请参考 mindspore.ops.tile(),当前接口的参数 reps 和详情参考接口中的参数 dims 实际为同一参数。