Abstract: Why can neural networks run on STM32? In short, it is to use the X-Cube-AI extension pack in STM32CubeMX to convert currently popular AI frameworks into C code to support usage on embedded devices. Currently, using X-Cube-AI requires STM32CubeMX version 5.0 or higher. Supported models for conversion include Keras, TFlite, ONNX, Lasagne, Caffe, and ConvNetJS. Cube-AI converts the model into a bunch of arrays, and then these array contents are parsed into models, which is similar to the principle of converting models to arrays in Tensorflow.
1. Environment Installation and Configuration
-
STM32CubeMX -
MDK/IAR/STM32CubeIDE -
F4/H7/MP157 Development Boards
2. Building AI Neural Network Models
Here we use the model provided by the official for testing, trained with the keras
framework:
data:image/s3,"s3://crabby-images/3c3fa/3c3fa7b55d0fa924b5549c925020449dcda18ca3" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
https://github.com/Shahnawax/HAR-CNN-Keras
Model Introduction
Using CNN in Keras for Human Activity Recognition: This repository contains code for a small project. The purpose of this project is to create a simple Human Activity Recognition (HAR) system based on Convolutional Neural Networks (CNN). This system uses sensor data from a 3D accelerometer to identify user activities, such as moving forward or backward. HAR stands for Human Activity Recognition system, which is to recognize human behavior. This model judges current behavior based on 3D acceleration data over a period of time, such as walking, running, going upstairs, and going downstairs, which is well-suited for the application scenarios of Cortex-M series MCUs. The data used is shown in the figure below.
data:image/s3,"s3://crabby-images/b48cd/b48cd628af52a3795e0664c28201c170438ed093" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
The repository contains the following files:
-
HAR.py, a Python script file that contains the Keras implementation of the CNN-based Human Activity Recognition (HAR) model, -
actitracker_raw.txt, a text file containing the dataset used in this experiment, -
model.h5
, a pre-trained model trained on the training data, -
evaluate_model.py, a Python script file that contains the evaluation script. This script evaluates the performance of the pre-trained network on the provided test data, -
testData.npy, a Python data file containing test data for evaluating the available pre-trained model, -
groundTruth.npy, a Python data file containing the ground truth corresponding to the test data outputs, and -
README.md.
Don’t panic with so many files; the model.h5
model obtained after model training is what we need.
3. Creating a New Project
1. It is assumed that everyone has already installed the STM32CubeMX software.
To verify the neural network model (HAR human activity recognition) on STM32, generally, high-performance microcontrollers from the STM32F3/F4/L4/F7/L7 series are required. Running the network model generally requires more than 3MB of flash memory space, and ordinary microcontrollers do not support such large space. CUBEMX provides a compression rate option, allowing selection of an appropriate compression rate, which actually compresses the neural network model’s weight coefficients, enabling the network model to run on the microcontroller. A compression rate of 8 reduces the model to 366KB, and verification can proceed;
data:image/s3,"s3://crabby-images/d09c0/d09c068f428c3c241a9e9b68ad2872f8d77f30bd" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Then follow the steps below to install the CUBE.AI extension pack properly.
data:image/s3,"s3://crabby-images/b5b73/b5b73cc00d8cc30a7197e70c84c0bc39b25b7169" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
I have installed three; just installing the latest version is sufficient.
data:image/s3,"s3://crabby-images/d2e97/d2e97a705fc28ddec0ac34f6070b6c22bd7ffc91" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Next, it’s time to familiarize yourself with creating a new project.
data:image/s3,"s3://crabby-images/c342a/c342a0827608c374b56637afb556bf45fde02e9e" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Because the AI package has been installed, the option artificial intelligence
will appear on this interface. Clicking Enable
allows you to see which chips support AI
.
data:image/s3,"s3://crabby-images/3a17c/3a17c54c4f185a64d3e535a84d9c9b9b2eab123a" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Next, configure the download interface and external crystal oscillator.
data:image/s3,"s3://crabby-images/94821/94821d5b84ea25b8b5fea4f8cfcfb2ebe32f885e" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
data:image/s3,"s3://crabby-images/d3013/d30136e27ee3e404e406946dab78f3e53a4d356f" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Then remember to select a serial port for debugging output.
data:image/s3,"s3://crabby-images/bab19/bab198d061a7e6177553dac902179bebeb2863d5" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Select Software Packs
, and then open the two packages related to AI
in the sidebar. Check the first one, and select Validation
in the first option.
data:image/s3,"s3://crabby-images/ff3a1/ff3a11063e0cc8f2cf7997cd865502461510a5f7" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
data:image/s3,"s3://crabby-images/8965d/8965d90b4f77a6c8abe6a42a99bfc2f3267e8abc" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
-
System Performance Project: The entire application project runs on the STM32MCU and can accurately measure NN inference results, CPU load, and memory usage. Use a serial terminal to monitor results (e.g., Tera Term) -
Validation Project: A complete application that incrementally verifies the results returned by NN through random or user test data in a desktop PC and embedded environment based on STM32 Arm Cortex-m. Used with the X-CUBE-A validation tool. -
Application Template Project: Allows building applications with an empty template project, including multi-network support.
Then in the left sidebar, open Software Packs
, select X-CUBE-AI
, and check both checkboxes in the pop-up Mode
window, then click on the network
tab in the Configuration
window.
data:image/s3,"s3://crabby-images/532fd/532fdb3666cd82d3988ac0367fbe36b86e64edd5" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Select the previously configured serial port for debugging.
data:image/s3,"s3://crabby-images/08e28/08e280f190e0c494b8c8ccb4c4a7b482e9fe5628" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Click add network
, select the downloaded model
h5 file, and choose a compression factor of 8;
data:image/s3,"s3://crabby-images/d932e/d932e12e4d458062c5e836ac651d2843240c6ddc" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Click analyze to see the comparison of model parameters before and after compression.
data:image/s3,"s3://crabby-images/9de92/9de92d4a77c63c9c6055ecc6fc5c72f14759bf7c" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Click validation on desktop to perform model validation on the PC, including comparisons between the original model and the converted model, and the validation results will also be displayed below.
data:image/s3,"s3://crabby-images/d5dd3/d5dd30cedb76a798a75206f2b7d277e86a711177" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Thus, the model validation is completed, and we will now start the model deployment.
4. Model Conversion and Deployment
The clock configuration will be done automatically by the system. Just configure the clock according to your microcontroller’s actual model.
data:image/s3,"s3://crabby-images/074bb/074bb655dd1c316fb90bd255399d67e9dc7ea41d" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
data:image/s3,"s3://crabby-images/f508f/f508f9f22974a151bf7682f715420d40f494ae07" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
data:image/s3,"s3://crabby-images/0b87b/0b87bc2dad46c7a6639301af12f994ea449f94ea" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Finally, click GENERATE CODE
to generate the project.
data:image/s3,"s3://crabby-images/5466d/5466d253b0f11cb9fbc1cedacfe3c6752e944d89" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
Then compile and link in MDK.
data:image/s3,"s3://crabby-images/33d07/33d07be35589245cc4ae94ec258145b8353f3301" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
After selecting the downloader, you can download the code.
data:image/s3,"s3://crabby-images/25024/250246e7ac193064418adec3b0b79e6d0f411db7" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
data:image/s3,"s3://crabby-images/3f8d9/3f8d96cb0c81ef9e38e69ba1236133ac10e96714" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
After the code is burned into the chip, return to CubeMX, and in the position shown in the figure below, we click Validate on target
to run the validation program on the board. The effect is shown in the figure below, it can work, proving that the model has been successfully deployed on the MCU.
data:image/s3,"s3://crabby-images/d90d5/d90d51884018fb7af4936adb9ce1bdbc05fa70e2" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
data:image/s3,"s3://crabby-images/a3997/a39970424884a7ac50e57828964b39d17b944647" alt="Running Neural Network Algorithms on STM32 Microcontrollers"
This time, let’s run the official example first, and then we can study and run our own models later.
References:
-
https://youtu.be/grgNXdkmzzQ?t=10 -
https://youtu.be/grgNXdkmzzQ?t=103