基于算子工程开发的算子,可以使用该接口实现CPU/NPU域assert断言功能。算子执行中,如果assert内部条件判断不为真,则输出assert条件并将输入的信息格式化打印在屏幕上。
1 2 3 4 5 |
int assertFlag = 10; assert(assertFlag == 10); assert(assertFlag == 10, "The assertFlag value is 10.\n"); assert(assertFlag == 10, "The assertFlag value is %d.\n", assertFlag); |
1
|
[ASSERT][CANN_VERSION : XXX.XX][TimeStamp : 20240807140556417] /home/.../add_custom.cpp:44: Assertion `assertFlag != 10' The assertFlag value is 10. |
1 2 |
assert(expr) assert(expr, __gm__ const char *fmt, Args&&... args) |
参数名 |
输入/输出 |
描述 |
---|---|---|
expr |
输入 |
assert断言是否终止程序的条件。为true则程序继续执行,为false则终止程序。 |
fmt |
输入 |
格式控制字符串,包含两种类型的对象:普通字符和转换说明。
|
args |
输入 |
附加参数,个数和类型可变的输出列表:根据不同的fmt字符串,函数可能需要一系列的附加参数,每个参数包含了一个要被插入的值,替换了fmt参数中指定的每个%标签。参数的个数应与%标签的个数相同。 |
无
Atlas A2训练系列产品/Atlas 800I A2推理产品
Atlas推理系列产品AI Core
1 2 3 4 5 6 7 8 9 10 11 |
int assertFlag = 10; // 断言条件 assert(assertFlag == 10); // 打印消息 assert(assertFlag == 10, "The assertFlag value is 10.\n"); // 格式化打印 assert(assertFlag == 10, "The assertFlag value is %d.\n", assertFlag); assert(assertFlag != 10, "The assertFlag value is %d.\n", assertFlag); |
程序运行时会触发assert,打印效果如下:
1
|
[ASSERT][CANN_VERSION : XXX.XX][TimeStamp : 20240807140556417] /home/.../add_custom.cpp:44: Assertion `assertFlag != 10' The assertFlag value is 10. |