Classify traffic signs thanks to an image classification model running on a STM32H7 microcontroller.
The use case presented is based on a German traffic sign dataset to classify road signs. The solution proposes models trained on a public dataset providing very good accuracy while running on a STM32.
These models were trained thanks to the Python scripts provided in STM32 model zoo (read our tutorial on the training to learn more).
Here, after setting up our STM32 Model Zoo project, we downloaded the dataset and placed it in the appropriate structure. Then we updated the yaml file, which was used to configure the training, with the following settings:
general:
project_name: traffic_sign
dataset:
name: traffic
class_names: ['0001', '0002', ..., '0042']
training_path: datasets/train
validation_path:
test_path: datasets/test
Feel free to adjust those settings according to your use-case.
Finally, we simply ran the "train.py" script.
You will find everything you need in the STM32 model zoo to train and retrain any model with your own data. The models can also be easily deployed on a STM32H747 discovery kit with the Python scripts provided in the repository (read our tutorial on the deployment to learn more).
You can find details of all these steps in our Getting started video.
The STM32 model zoo contains several models for image classification, so you can choose the one best suited to your project.
Here, we have trained 2 different models for the same use-case, each with its own performance and memory footprints:
Model MobileNetV2 alpha 0.35
Input size: 128x128x3
Memory footprint of the quantized model:
Total RAM: 272 KB
Total Flash: 563 KB
Accuracy:
Float model: 99.87%
Quantized model: 99.57%
Performance on STM32H747 (High-perf) @ 400 MHz
Inference time: 101 ms
Frame rate: 9.9 fps
Model FDMobileNet
Input size: 128x128x3
Memory footprint of the quantized model:
Total RAM: 65 KB
Total Flash: 192 KB
Accuracy:
Float model: 99.78%
Quantized model: 99.51%
Performance on STM32H747 (High-perf) @ 400 MHz
Inference time: 20.04 ms
Frame rate: 49.9 fps
Confusion matrix of the quantized MobiNetV2 model
A collection of reference AI models optimized to run on ST devices with associated deployment scripts. The model zoo is a valuable resource to add edge AI capabilities to embedded applications.
A free STM32Cube expansion package, X-CUBE-AI allows developers to convert pretrained AI algorithms automatically, such as neural network and machine learning models, into optimized C code for STM32.
The STM32 family of 32-bit microcontrollers based on the Arm Cortex®-M processor is designed to offer new degrees of freedom to MCU users. It offers products combining very high performance, real-time capabilities, digital signal processing, low-power / low-voltage operation, and connectivity, while maintaining full integration and ease of development.