Machine Learning on Mainstream Microcontrollers †

This paper presents the Edge Learning Machine (ELM), a machine learning framework for edge devices, which manages the training phase on a desktop computer and performs inferences on microcontrollers. The framework implements, in a platform-independent C language, three supervised machine learning algorithms (Support Vector Machine (SVM) with a linear kernel, k-Nearest Neighbors (K-NN), and Decision Tree (DT)), and exploits STM X-Cube-AI to implement Artificial Neural Networks (ANNs) on STM32 Nucleo boards. We investigated the performance of these algorithms on six embedded boards and six datasets (four classifications and two regression). Our analysis—which aims to plug a gap in the literature—shows that the target platforms allow us to achieve the same performance score as a desktop machine, with a similar time latency. ANN performs better than the other algorithms in most cases, with no difference among the target devices. We observed that increasing the depth of an NN improves performance, up to a saturation level. k-NN performs similarly to ANN and, in one case, even better, but requires all the training sets to be kept in the inference phase, posing a significant memory demand, which can be afforded only by high-end edge devices. DT performance has a larger variance across datasets. In general, several factors impact performance in different ways across datasets. This highlights the importance of a framework like ELM, which is able to train and compare different algorithms. To support the developer community, ELM is released on an open-source basis.

[1]  Sergey Ioffe,et al.  Batch Normalization: Accelerating Deep Network Training by Reducing Internal Covariate Shift , 2015, ICML.

[2]  Ardi Kolah ‘The Age of Surveillance Capitalism — The Fight for a Human Future at the New Frontier of Power’ , 2019 .

[3]  Riccardo Berta,et al.  Developing a Machine Learning Library for Microcontrollers , 2018, ApplePies.

[4]  Alessandro De Gloria,et al.  A Fuzzy Logic Module to Estimate a Driver's Fuel Consumption for Reality-Enhanced Serious Games , 2018, Int. J. Serious Games.

[5]  Ying Bai,et al.  Practical Microcontroller Engineering with ARM­ Technology , 2015 .

[6]  Marimuthu Palaniswami,et al.  Internet of Things (IoT): A vision, architectural elements, and future directions , 2012, Future Gener. Comput. Syst..

[7]  Shai Ben-David,et al.  Understanding Machine Learning: From Theory to Algorithms , 2014 .

[8]  Elisabetta Farella,et al.  Convolutional Neural Network on Embedded Platform for People Presence Detection in Low Resolution Thermal Images , 2019, ICASSP 2019 - 2019 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP).

[9]  Prateek Jain,et al.  FastGRNN: A Fast, Accurate, Stable and Tiny Kilobyte Sized Gated Recurrent Neural Network , 2018, NeurIPS.

[10]  Ming Zhao,et al.  Are Existing Knowledge Transfer Techniques Effective for Deep Learning with Edge Devices? , 2018, 2018 IEEE International Conference on Edge Computing (EDGE).

[11]  Ajay Joshi,et al.  Towards Deep Learning using TensorFlow Lite on RISC-V , 2019 .

[12]  Y. Fisher,et al.  Comparison of Results , 1995 .

[13]  Riccardo Berta,et al.  Analyzing Machine Learning on Mainstream Microcontrollers , 2019, ApplePies.

[14]  Weisong Shi,et al.  Edge Computing: Vision and Challenges , 2016, IEEE Internet of Things Journal.

[15]  Stefan Poslad,et al.  Towards a Reality-Enhanced Serious Game to Promote Eco-Driving in the Wild , 2019, GALA.

[16]  Alessandro FAUSTO,et al.  Implementation details to reduce the latency of an SDN Statistical Fingerprint-Based IDS , 2019, 2019 International Symposium on Advanced Electrical and Communication Technologies (ISAECT).

[17]  Wei-Yin Loh,et al.  Classification and regression trees , 2011, WIREs Data Mining Knowl. Discov..

[18]  Mario Marchese,et al.  Statistical fingerprint‐based intrusion detection system (SF‐IDS) , 2017, Int. J. Commun. Syst..

[19]  Mohamed Medhat Gaber,et al.  Edge Machine Learning: Enabling Smart Internet of Things Applications , 2018, Big Data Cogn. Comput..

[20]  Georgios C. Anagnostopoulos,et al.  A Simple Method for Solving the SVM Regularization Path for Semidefinite Kernels , 2016, IEEE Transactions on Neural Networks and Learning Systems.

[21]  Michele Magno,et al.  DeepEmote: Towards multi-layer neural networks in a low power wearable multi-sensors bracelet , 2017, 2017 7th IEEE International Workshop on Advances in Sensors and Interfaces (IWASI).

[22]  Yoshua Bengio,et al.  Scaling learning algorithms towards AI , 2007 .

[23]  Hai Jin,et al.  Computation Offloading Toward Edge Computing , 2019, Proceedings of the IEEE.

[24]  Yingjie Zhang,et al.  The Implementation of CNN-Based Object Detector on ARM Embedded Platforms , 2018, 2018 IEEE 16th Intl Conf on Dependable, Autonomic and Secure Computing, 16th Intl Conf on Pervasive Intelligence and Computing, 4th Intl Conf on Big Data Intelligence and Computing and Cyber Science and Technology Congress(DASC/PiCom/DataCom/CyberSciTech).

[25]  Katarina Grolinger,et al.  Deep Learning: Edge-Cloud Data Analytics for IoT , 2019, 2019 IEEE Canadian Conference of Electrical and Computer Engineering (CCECE).

[26]  Trevor Darrell,et al.  Nearest-Neighbor Methods in Learning and Vision , 2008, IEEE Trans. Neural Networks.

[27]  Vivek Seshadri,et al.  Compiling KB-sized machine learning models to tiny IoT devices , 2019, PLDI.

[28]  Maurizio Valle,et al.  Smart Tactile Sensing Systems Based on Embedded CNN Implementations , 2020, Micromachines.

[29]  Michele Magno,et al.  FANNCortexM: An Open Source Toolkit for Deployment of Multi-layer Neural Networks on ARM Cortex-M Family Microcontrollers : Performance Analysis with Stress Detection , 2019, 2019 IEEE 5th World Forum on Internet of Things (WF-IoT).