作者:Florentw,AMD工程师;来源:AMD Xilinx开发者社区
简介
在 AI 引擎系列的前 3 篇博文中,我们探讨了 AI 引擎应用所需的不同文件。在本篇中,我们将为 X86 目标运行 AI 引擎编译器,观察它生成的不同输出。
要求
下文要求您通读前几篇。
AI 引擎系列 1 - 从 AI 引擎工具开始(2022.1 更新)
AI 引擎系列 2 - AI 引擎 graph 简介 (2022.1 更新)
AI 引擎系列 3 - AI 引擎内核简介
首次运行 AI 引擎编译器
在前几篇博文中所创建的工程中,打开“simple_application.prj”工程以查看“Application Project Settings”(应用工程设置)。
在右上角可以看到有 3 个可用的构建配置:
请选中“Emulation-SW”。这样“Target”(目标)会改为“x86 Simulation”(x86 仿真)
选中“AI Engine Application”(AI 引擎应用)(simple_application),然后单击工具栏中的锤子按钮以构建该工程。
这样即可在控制台窗口中看到 aiecompiler 命令的运行过程。
启动的完整命令如下所示:
aiecompiler -v --stacksize=1024 --heapsize=1024 -Xchess=main:darts.xargs=-nb -include="
可用不同选项包括:
-v:为 aiecompiler 启用详细模式
-include:用于包含必要的头文件、源文件和数据文件。
-stacksize:该选项用于定义所有核的 stacksize 大小
-heapsize:该选项用于定义所有核的 heapsize 大小
-target=x86sim:该选项用于将 x86 仿真设为目标。
-platform:该选项用于定义平台(此处采用 VCK190 基础平台)路径
-workdir:该选项用于指定 aiecompiler 的输出文件夹
最后一个参数 (../src/project.cpp) 是顶层文件,其中包含顶层计算图 (graph) 的例化。
完成构建后,即可在“Explorer”(资源管理器)窗口中看到,编译器已生成名为“Emulation-SW”的文件夹,并且编译输出包含在“Work”目录中
此时即可运行 X86 仿真。选中“AI Engine Application”(simple_application),然后单击“Run As”图标旁的箭头,单击“Run As > Launch SW Emulator”(运行方式 > 启动软件仿真器)
完成仿真后,Vitis 中的控制台应报告“Simulation completed successfully returning zero”(仿真已成功完成,返回 0)。
在“Emulation-SW”文件夹下可以看到,仿真器已生成 data 目录,其中,根据 project.h 顶层计算图文件指定的要求,output.txt 内包含来自仿真器的输出
out = output_plio::create(plio_32_bits, "data/output.txt");
模板示例随附了黄金参考文件 (data/golden.txt) 供我们与输出文件进行比对。请选中 golden.txt 文件和新创建的 output.txt,右键单击其中之一,然后单击“Compare With > Each Other”(比较对象 > 相互比较)。
通过比较这 2 个文件可以看到两者相匹配,这表示代码功能正常(它与模型相匹配)。
下一步
在下一篇博文中,我们将以 AI 引擎模型为目标来运行 AI 引擎编译器。