Embedded Machine Learning Ecosystem (EMLE -> EMILY) is an intuitive, beginner-friendly platform aimed at simplifying the creation and deployment of machine learning models on embedded devices.
Our simple, easy-to-use User Interface (UI) guides the user through the entire pipeline required for constructing an audio classifier and deploying it to a microcontroller. This includes:
- selecting a dataset,
- choosing and tuning an audio processing method,
- configuring ML-related parameters for the model training,
- directly uploading their models to Arduino for running inference (without the need for manual steps in the Arduino IDE).
Our application is an all-in-one package.
Run the main.py python script from the UI folder.
Requirements: For this project we only require that Python (3.9) and PIP are installed. After this please run pip install -r requirements.txt
using the requirements.txt file of the repository. This will automatically install all other packages used in the project.
If you want you can use a virtual environment and install the requirements there (pip install virtualenv
).
Tested Operating Systems: Windows 10, Linux, MacOS.
Tested Arduino Boards: Arduino Nano 33 BLE Sense
Download / Clone this repo and make sure you have the above requirements installed.
Open the emily.spec
file and change the pathex
to the root directory of the project.
In the same file, change line 24 such that the first argument of the tuple is the path to your local \\librosa\\util\\example_data
.
Open terminal at the root of the project and type the following:
pip install pyinstaller
pyinstaller emily.spec
If you face any issues with the above, run terminal as admin. If all goes well you should have an executable within the dist folder generated by the above command.
- main.py: Main UI frontend file. Everything from the backend is called from here. (the gif shown is the UI home page)
-
scripts (folder): Contains all scripts that form the backend, and is divided further into four folders which represent the four blocks in the pipeline:
- dataset: Contains everything related to accessing and loading the audio dataset. Achieves the following:
- Choose the source of the dataset. Options: load from local directory, download from URL, create dataset within our UI
- Set important dataset parameters, such as the expected track duration and the sampling rate
- processing: Contains everything related to preprocessing the audio dataset. Achieves the following:
- Choose the signal processing method. Options: Averaging, Short Time Fourier Transform, Windowed Root Mean Square
- Configure processing by tuning algorithm parameters
- Option to streamline the input pipeline
- training: Contains everything related to training, converting, and saving the model. Achieves the following:
- Set various ML-related parameters
- Choose between Convolutional and Dense models.
- Real-time plotting of model performance
- Model quantization and quantization-aware training
- Convert model to form readable by the microcontroller and save it in user-selected destination
- arduino: Contains everything related to deploying the arduino script as well as the model chosen for inference. Achieves the following:
- Compile and upload ready-made Arduino script for preprocessing and inference.
- Pass dataset and processing parameters to Arduino through the model file.
- Automated deployment to microcontroller through Arduino-CLI.
- Live feedback from the CLI through a custom CMD.
- dataset: Contains everything related to accessing and loading the audio dataset. Achieves the following:
-
arduino_inference_script (folder): Contains the following files:
- Arduino script implementing the Arduino-side pipeline. This includes audio reception from the on-board microphone, audio signal processing, as well as inference using the uploaded model file.
- A header (.h) file containing the model chosen for upload as well as other dataset and processing parameters that need to be communicated to the Arduino.
-
arduino_recording_script (folder): Arduino script uploaded for recording a dataset from within the UI, since we utilize the arduino microphone.
- imports.py: Contains all imports currently used.
- Images (folder): Contains images used as icons within the UI.
- requirements.txt: Contains all packages used in the project, used for installing allof them at the same time using PIP (see How to run section).
- UI_gifs: Contains GIFs of the UI in operation used in the README.
- Andreas Floros
- Bharat Kumar
- Hussain Kurabadwala
- Vasileios Manginas
- Stacey Wu
ARM Team:
- Henri Woodcock
- Sandeep Mistry
Project supervisor (Imperial College London):
- Dr. Krystian Mikolajczyk