Skip to content

Latest commit

 

History

History

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 

AMD Vitis™ AI Engine

See Vitis Development Environment on xilinx.com

AI Engine Development

Introduction

The tutorials under the AI Engine Development help you learn how to target, develop, and deploy advanced algorithms using a Versal AI Engine array in conjunction with PL IP/kernels and software applications running on the embedded processors. To successfully deploy AI Engine applications in hardware, you need to be aware of the Vitis and AI Engine tools and flows.

  • The AI Engine Development Feature Tutorials highlight specific features and flows that help develop AI Engine applications.

  • The AI Engine Development Design Tutorials showcase the two major phases of AI Engine application development: architecting the application and developing the kernels. Both phases are demonstrated in these tutorials.

Getting Started

AI Engine Documentation

To easily find the right documentation corresponding to the development stage you are at, we recommend you use the AI Engine Design Process Hub.

The major documentation for AI Engine includes:

  • Versal ACAP AI Engine Architecture Manual AM009
  • AI Engine Tools and Flows UG1076
  • AI Engine Kernel and Graph Programming Guide UG1079

AI Engine Training

If you are new with AI Engine, the following training courses can help you understand the architechure and design flow.

Environment Settings

IMPORTANT: Before beginning the tutorial make sure you have read and followed the Vitis Release Notes And Installation Guide (UG1742) (v2024.2) for setting up software and installing the VCK190 base platform.

Run the following steps to setup environment (do NOT apply to tutorials that do not use the VCK190 base platform):

  1. Set up your platform by running the xilinx-versal-common-v2024.2/environment-setup-cortexa72-cortexa53-xilinx-linux script as provided in the platform download. This script sets up the SYSROOT and CXX variables. If the script is not present, you must run the xilinx-versal-common-v2024.2/sdk.sh command.
  2. Set up your ROOTFS to point to the xilinx-versal-common-v2024.2/rootfs.ext4.
  3. Set up your IMAGE to point to xilinx-versal-common-v2024.2/Image.
  4. Set up your PLATFORM_REPO_PATHS environment variable based upon where you downloaded the platform.

Getting Started with AI Engine Development Using the AI Engine Tutorials

missing image

If you are new with the AI Engine Architecture and tools, we recommend that you start with the A to Z Bare-metal Flow, which will guide you through the entire flow from platform creation in AMD Vivado™ to AI Engine application creation, system integration and testing on Hardware using the Vitis IDE.

AI Engine Application Development

To get started with AI Engine application development, we recommend that you look at the following tutorials:

  • DSP Library Tutorial which will guide you to create an AI Engine using application using the AMD provided DSP library
  • AIE DSPLib and Model Composer which will also guide you to create an AI Engine using application using the AMD provided DSP library but using the ModelComposer tool which enables easy designs through a MATLAB Simulink environment.
  • Using GMIO with AIE which goes through using the GMIOs for connectivity between the AI Engine and the DDR (through the NoC)
  • Implementing an IIR Filter on the AIE will guide you into custom kernel coding using a IIR application

The following tutorials describe some features of the AI Engine, which might be useful for your application:

AI Engine Application Debug and Optimization

After you have written your first AI Engine application you might want to verify the correct functionality of your graphs and kernels using x86 simulation and AI Engine simulation. In this regards, the following tutorials will be useful for you:

System Integration

When your AI Engine Application meets your expectation (in terms of functionality and performances), it will be the right time to integrate it with the rest of the Versal System. At this stage, the following tutorials will be useful for you:

  • AIE Versal Integration. This tutorial demonstrates creating a system design running on the AI Engine, PS, and Programmable Logic (PL).
  • Versal System Design Clocking. In this tutorial, you will learn clocking concepts for the Vitis compiler and how to define clocking for an ADF Graph, as well as PL kernels using clocking automation functionality.
  • Versal Emulation Waveform Analysis which demonstrates how you can use the Vivado Design Suite logic simulator (XSIM) waveform GUI, and the Vitis analyzer to debug and analyze your design.

Available Tutorials

Feature Tutorials

These tutorials target the VCK190 board. The table below lists the tutorials available, and the features and flows showcased in all of these tutorials. The various columns correspond to specific features/flows supported in these tutorials and will help you identify tutorials that showcase specific flows and features that you are interested in.

Tutorial Platform OS IDE Flow Libraries Used HLS Kernel x86 simulator aie simulator SW Emu HW Emu HW Event Trace in HW Profile in HW
AI Engine A-to-Z Flow for Linux Base / Custom Linux MM2S / S2MM Yes Yes Yes Yes Yes
A to Z Bare-metal Flow Custom Baremetal Vivado &
Vitis IDE
MM2S / S2MM Yes Yes Yes
Using GMIO with AIE Base Linux Yes Yes Yes Yes
Runtime Parameter Reconfiguration Base Linux MM2S / S2MM Yes Yes Yes
Packet Switching Base Linux MM2S / S2MM Yes Yes Yes
AIE Versal Integration Base Linux CLI / Vitis Unified IDE MM2S / S2MM Yes Yes Yes Yes Yes
Versal System Design Clocking Base Linux MM2S / S2MM Yes Yes Yes
Using Floating-Point in the AIE Base Linux Yes
DSP Library Tutorial Base Linux DSPLib MM2S / S2MM Variant Yes
Debug Walkthrough Tutorial Base Linux Vitis IDE Yes Yes Yes Yes Yes Yes Yes
AIE DSPLib and Model Composer Base Linux Simulink DSPLib MM2S / S2MM Yes Yes
Versal Emulation Waveform Analysis Base Linux Traffic Generators Yes
AIE Performance and Deadlock Analysis Base Linux Yes Yes Yes Yes
Implementing an IIR Filter on the AIE Base Linux Vitis IDE Yes Yes
Post-Link Recompile of an AIE Application Base Linux MM2S / S2MM Yes Yes Yes
Python and C++ External Traffic Generators for AI Engine Simulation and Emulation Flows Base Linux MM2S / S2MM / PolarClip Yes Yes Yes Yes
Using RTL IP with AI Engines Custom Linux MM2S / S2MM Yes Yes
AIE Compiler Features Base Linux MM2S / S2MM Yes Yes Yes Yes Yes Yes
Two Tone Filter Base Linux Yes DSPLib Yes Yes
Compiling AIE Graphs for Independent Partitions Base Linux MM2S / S2MM Yes Yes Yes Yes Yes
RTL / AI Engine interfacing Examples Custom N/A Vivado & Vitis IDE Yes

Design Tutorials

These tutorials target the VCK190 board. The table below lists the tutorials available, and the features and flows showcased in all of these tutorials. The various columns correspond to specific features/flows supported in these tutorials and will help you identify tutorials that showcase specific flows and features that you are interested in.

Tutorial Platform OS IDE Flow Libraries Used HLS Kernel x86 simulator aie simulator SW Emu HW Emu HW Event Trace in HW Profile in HW
Versal Custom Thin Platform Extensible System Custom Linux MM2S / S2MM / VADD Yes Yes
LeNet Tutorial Base Linux MM2S / S2MM Yes Yes Yes Yes
Super Sampling Rate FIR Filters Base Linux Yes
Beamforming Design Base Linux Yes Yes Yes Yes
Polyphase Channelizer Base Linux MM2S / S2MM Yes Yes
Prime Factor FFT Base Linux MM2S / S2MM Yes Yes
2D-FFT Base Linux DSPLib PL Data Generator and Checker Yes Yes Yes Yes
FIR Filter Base Linux DSPLib PL Data Generator and Checker Yes Yes Yes Yes
N-Body Simulator Base Linux PL Datamover Yes Yes Yes
Digital Down-conversion Chain Base Linux Yes Yes
Versal GeMM Implementation Base Linux DSPLib Datamover Yes Yes Yes Yes
Bilinear Interpolation Base Linux Yes Yes
64K IFFT Using 2D Architecture Base Linux MM2S / S2MM Yes Yes
FFT and DFT on AI Engine Base Linux DSPLib Yes Yes
Bitonic SIMD Sorting on AI Engine Base Linux Yes Yes
Fractional Delay Farrow Filter Base Linux Data Movers Yes Yes Yes Yes
1M Point float FFT @ 32 Gsps Custom Baremetal Yes Yes Yes Yes
System Partitioning of a Hough Transform Base Linux Yes Yes
MUSIC Algorithm on AI Engine Base Linux MM2S / S2MM Yes
Softmax Function on AI Engine Base Linux Yes Yes
Time-Division Multiplexed Mixer Base Linux Yes Yes

Copyright © 2020–2024 Advanced Micro Devices, Inc

Terms and Conditions