AI-deck-workshop

Copyright (C) 2021 ETH Zürich, University of Bologna. All rights reserved.

Authors: Lorenzo Lamberti (University of Bologna), Hanna Müller (ETH Zürich), Vlad Niculescu (ETH Zürich), Dr. Manuele Rusci (University of Bologna / Greenwaves Technology), Dr. Daniele Palossi (IDSIA Lugano / ETH Zürich)

This workshop on the AI-Deck was held on April 16th 2021. More info about the event at this page.

Video Recording: The workshop's recording is available on the offical Bitcraze's YouTube Channel at this link

The workshop is composed of two main parts:

  1. An overview on the PULP (Parallel Ultra Low Power) paradigm and the PULP architecture: slides available at Overview/
  2. Four hands-on sessions with PULP coding examples: code and slides available at Hands-on/.

Hands-on sessions

A brief description of the hands-on sessions is provided in the following sections.

1. Basic programming

This hands-on shows you how to connect to your AI-deck and how to run your first program on it. It also introduces basic API functions for executing code on multiple cores. The example will print hello world from all cores. You find more infos about the code in the README inside the helloworld example.

2. Image manipulation

This example takes an image, applies a kernel and writes the image over your JTAG cable (using openOCD file semi-hosting) to your computer. You can choose between two kernels:

  • demosaicking
  • inverting

for both you can choose to either execute the kernel sequentially on the fabric controller or parallelized on the cluster. It is meant to introduce the camera, file transmission via JTAG and parallization of image processing kernels. You find more infos about the code in the README inside the simple_kernel_example.

3. Firmware integration

This example shows how to communicate via UART between the AI-deck and the STM32 in the Crazyflie. The example consists of two parts: the code to be flashed in the GAP8 and the Crazyflie application.

  1. The GAP8 code initializes the UART and then sends a counter value every 0.5ms.
  2. The Crazyflie application shows how to use UART together with DMA. Whenever the counter value is received from GAP8, an interrupt is triggered in the STM32, which signals the application to print the counter value in the console.

4. Video streaming

These two examples show how to stream JPEG images from the AI-Deck to a socket connected via Wi-FI.

  1. wifi_jpeg_streamer/ example streams normal grayscale images
  2. wifi_jpeg_streamer_inv_filter/ example streams grayscale images with inverted colors, using the inverting() from Hands-on session 2.

The acquisition and JPEG encoding of the acquired image hapens on the GAP8 SoC, while the Wi-Fi transmission is managed by the NINA Wi-Fi module. The code consists of two pars:

  • wifi_jpeg_streamer/test.c: the GAP8 C code (camera acquisition of a raw image, jpeg encoding, forward of the jpeg image to NINA)
  • viewer.py: the Python visualizer receives the images streamed from NINA to the Laptop. By default, it connects to the IP of the AI-deck when use in AccessPoint mode.

Tested on GAP_SDK version 3.8.1.

Commands: Flash GAP8 memory with our code:

cd GAP8/wifi_jpeg_streamer/ 
make clean all
make image flash io=host

Alternatively, you can run code on GAP8 from L2 memory (volatile)

cd GAP8/wifi_jpeg_streamer/ 
make clean all run io=host

Visualize images:

cd GAP8/
python viewer.py

More documentation:

Bitcraze instructions

Install GAP sdk