- System Requirements
- Hardware
- Support MPSoC (DPUCZDX8G)
- Support Alveo (DPUCAHX8H)
- Software
- Support VART v1.2+
- Support Vitis AI Library v1.2+
- Hardware
- Installing
- Deploy the web server (Vitis AI Profiler) on PC or local
server
- Clone the Vitis AI Profiler Project from github
repo.
# cd /path-to-vitis-ai/Vitis-AI-Profiler
- Requirements
- Python 3.6+
- Flask which you can get
from
# pip3 install --user flask
- Start the web Server on PC or Local Network
Server.
# python3 vaiProfilerServer.py [–ip [0.0.0.0]] [--port [8008]]
By default (run with no argument) the IP address is 0.0.0.0 and port number is 8008, so user can access the web page by http://localhost:8008
- Clone the Vitis AI Profiler Project from github
repo.
- Preparing debug environment for VAI trace in MPSoC platform
- Configure and Build Petalinux
- Run petalinux-config -c kernel and Enable
these for linux
kernel
General architecture-dependent options ---> [*] Kprobes Kernel hacking ---> [*] Tracers Kernel hacking ---> [*] Tracers ---> [*] Kernel Function Tracer [*] Enable kprobes-based dynamic events [*] Enable uprobes-based dynamic events
- Run petalinux-config -c rootfs
and enable this for root-fs
user-packages ---> modules ---> [*] packagegroup-petalinux-self-hosted
- Run petalinux-build
- Run petalinux-config -c kernel and Enable
these for linux
kernel
- Install vart runtime, vaitrace will be installed into /usr/bin/xlnx/vaitrace
- Create a symbolic
link
#ln -s /usr/bin/xlnx/vaitrace/vaitrace.py /usr/bin/vaitrace
- Configure and Build Petalinux
- Installing VAI trace
- Install vart runtime, vaitrace will be installed into /usr/bin/xlnx/vaitrace
- Create a symbolic
link
#ln -s /usr/bin/xlnx/vaitrace/vaitrace.py /usr/bin/vaitrace
- Deploy the web server (Vitis AI Profiler) on PC or local
server
- Starting trace with vaitrace:
Use the “test_performance” program of Vitis AI Library’s yolov3 sample as an example
- Download and Install Vitis AI Library
- Entry the directory of yolov3
sample
# cd /usr/share/vitis_ai_library/samples/yolov3/
- Start testing and tracing
See readme file and the test command is:
# vaitrace –t 5 –o ~/trace_yolo_v3.xat ./test_performance_yolov3 yolov3_voc ./test_performance_yolov3.list
- The first argument [-t 5] stands for tracing for 5 seconds.
- The second argument [-o ~/trace_yolo_v3.xat] stands for saving the tracing data to home directory and named as trace_yolo_v3.xat, if no specified, the tracing data file(.xat) will be saved in the same directory with the executable file.
- Copy the .xat file from home directory to your PC(via scp or nfs.)
- Upload and Get Result in Vitis AI Profiler
- Open the Vitis AI Profiler with your browser (http://127.0.0.1:8008) .
- Click 'Browse' button to select the .xat file then click ‘Upload’Figure 1. .xat File Upload Page
- Now there four parts on the Profiler UI
-
Timeline: The timeline is categorized by hardware components users can tell hardware utilization with just at a single glance. All Vitis AI Library relative tasks are high-lighted, and most of the other progress are filtered out when tracing for higher efficiency, so the trace info of other threads may be inaccuracy.
For CPU tasks in timeline, different color indicates different thread, click on color block in the timeline will jump to and show the details in the tree-grid table below
- Throughput: Show real-time Vitis AI Library inference FPS
- AXI traffic: Total AXI read and write bandwidth, all six AXI ports included for Zynq MPSoC, not supported for cloud solution now.
- Hardware Information: Show CPU/Memory/CU relative information
-