昇腾社区首页
中文
注册
开发者
下载

assert

产品支持情况

产品

是否支持

Atlas A3 训练系列产品/Atlas A3 推理系列产品

Atlas A2 训练系列产品/Atlas A2 推理系列产品

Atlas 200I/500 A2 推理产品

x

Atlas 推理系列产品AI Core

x

Atlas 推理系列产品Vector Core

x

Atlas 训练系列产品

x

功能说明

该接口实现AI CPU算子Kernel调试场景下的assert断言功能。使用时需要包含头文件aicpu_api.h。

算子执行中,如果assert内部条件判断不为真,则输出assert条件、触发文件名、行号等信息。

函数原型

1
assert(expr)

参数说明

参数名

输入/输出

描述

expr

输入

assert断言是否终止程序的条件。为true则程序继续执行,为false则终止程序。

返回值说明

约束说明

  • kernel开发不要包含系统的assert.h,会导致宏定义冲突。
  • assert接口调用形式与C语言一致,不需要使用AscendC命名空间。
  • 该接口使用Dump功能,所有使用Dump功能的接口在每个核上Dump的数据总量不可超过1M。请开发者自行控制待打印的内容数据量,超出则不会打印。
  • 使用该接口时,若采用bisheng命令行编译,开发者需要手动链接相关的静态库;而使用CMake编译时,框架会自动处理链接问题,无需开发者额外关注。具体编译命令如下:通过--cce-aicpu-laicpu_api为Device链接libaicpu_api.a,通过--cce-aicpu-L指定libaicpu_api.a的库路径。
    $bisheng -O2 foo.aicpu --cce-aicpu-L${INSTALL_DIR}/toolkit/lib64/device/lib64 --cce-aicpu-laicpu_api -I${INSTALL_DIR}/include/ascendc/aicpu_api -c -o foo.aicpu.o

    ${INSTALL_DIR}请替换为CANN软件安装后文件存储路径。若安装的Ascend-cann-toolkit软件包,以root安装举例,则安装后文件存储路径为:/usr/local/Ascend/ascend-toolkit/latest。

调用示例

在算子kernel侧实现代码中需要增加断言的地方使用assert检查代码示例如下:

1
2
3
int assertFlag = 10;
// 断言条件
assert(assertFlag == 12);

程序运行时会触发assert,打印效果如下:

1
[ASSERT]` assertFlag == 12 ' at /home/.../test.cpp:36