mindspore.ops.TensorDump

查看源文件
class mindspore.ops.TensorDump(input_output='out')[源代码]

将Tensor保存为numpy格式的npy文件。

警告

  • 参数input_output将不再支持参数值为'all'。

说明

  • 在Ascend平台上的Graph模式下,可以通过设置环境变量 MS_DUMP_SLICE_SIZEMS_DUMP_WAIT_TIME 解决在输出大Tesnor或输出Tensor比较密集场景下算子执行失败的问题。

参数:
  • input_output (str,可选) - 控制Tensordump行为模式的参数,可选的值为 ['out', 'in'] 中的一个,默认值: out

    对于算子A –> 重排算子 –> 算子B这样的情况,由于重排算子的插入,导致算子A的输出不再等价于算子B的输入。

    假设一种情况是算子A的计算结果既作为算子B的输入,也作为Tensordump算子的输入。则在该情况下, 通过设置input_output参数可以实现不同的保存数据的需求:

    • 如果input_output参数设置为'out',保存的数据仅包含算子A的输出分片。

    • 如果input_output参数设置为'in',保存的数据将仅包含算子B的输入分片。

    当input_output参数被配置为'in'时,生成的输入分片所对应的npy文件命名格式为:fileName_dumpMode_dtype_id.npy。

    当input_output参数被配置为'out'时,生成的输出分片所对应的npy文件命名格式为:fileName_dtype_id.npy。

    • fileName:参数file的值 (若该参数传入时是一个使用者指定的路径,则fileName的值为路径的最后一级)。

    • dumpMode:input_output参数的值。

    • dtype:原始的数据类型。bfloat16类型数据保存在.npy文件中会被转换成float32类型。

    • id:一个自增的ID。

输入:
  • file (str) - 要保存的文件路径。

  • input_x (Tensor) - 任意维度的Tensor。

异常:
  • TypeError - 如果 file 不是str。

  • TypeError - 如果 input_x 不是Tensor。

支持平台:

Ascend

样例:

>>> import numpy as np
>>> import mindspore as ms
>>> import time
>>> from mindspore import nn, Tensor, ops
>>> ms.set_context(mode=ms.GRAPH_MODE)
>>> ms.set_device(device_target="Ascend")
>>> class Net(nn.Cell):
...     def __init__(self):
...         super(Net, self).__init__()
...         self.dump = ops.TensorDump()
...
...     def construct(self, x):
...         x += 1.
...         self.dump('add', x)
...         x /= 2.
...         self.dump('div', x)
...         x *= 5.
...         self.dump('mul', x)
...         return x
...
>>> x = np.array([[1, 2, 3, 4], [5, 6, 7, 8]]).astype(np.float32)
>>> input_x = Tensor(x)
>>> net = Net()
>>> out = net(input_x)
>>> time.sleep(0.5)
>>> add = np.load('add_float32_0.npy')
>>> print(add)
[[2. 3. 4. 5.]
 [6. 7. 8. 9.]]