npu_print

函数功能

在图执行过程中,打印执行脚本中目标tensor值。该接口类似原生的print接口,但不会导致断图,详细功能介绍参见图内Tensor打印功能

函数原型

def npu_print(*args, summarize_size=3)

参数说明

参数

输入/输出

说明

是否必选

*args

输入

位置入参,其中每个入参支持的数据类型为torch.Tensor、str、bool、float、int等基本类型,且其中至少包含一个Tensor类型输入。

summarize_size

输入

tensor每个维度显示的数据元素个数,默认值为3。

  • 取值为-1:打印全部数据元素。
  • 取值为正整数且大于等于(tensor维度的最大dim/2)时:打印全部数据元素。
  • 取值为正整数且小于(tensor维度的最大dim/2)时:对于tensor每个维度,起始位置打印summarize_size个数据元素,末端位置打印summarize_size个数据元素,中间元素以“...”表示。

例如shape为[10, 10]的tensor,当summarize_size=3,打印结果示例如下:

1
2
3
4
5
6
7
[[1 2 3 …… 8 9 10]
[1 2 3 …… 8 9 10]
[1 2 3 …… 8 9 10]
……
[1 2 3 …… 8 9 10]
[1 2 3 …… 8 9 10]
[1 2 3 …… 8 9 10]]

返回值说明

约束说明

调用示例

1
2
3
4
5
6
7
8
9
import torch
import torch_npu, torchair

@torch.compile(backend="npu", fullgraph=True)
def hello_tensor(x):
    torchair.ops.npu_print("hello, tensor:", x)

v = torch.arange(10).npu()
hello_tensor(v)                          # 打印结果为"hello, tensor: [0 1 2 ... 7 8 9]"