This repository is an example on how to add a custom learning block to Edge Impulse. This repository contains a small fully-connected model built in Keras & TensorFlow. If you want to see a more complex example, see edgeimpulse/efficientnet. Or if you're looking for the PyTorch version of this repository, see edgeimpulse/example-custom-ml-block-pytorch.
As a primer, read the Custom learning blocks page in the Edge Impulse docs.
You run this pipeline via Docker. This encapsulates all dependencies and packages for you.
-
Install Docker Desktop.
-
Install the Edge Impulse CLI v1.16.0 or higher.
-
Create a new Edge Impulse project, and add data from the continuous gestures dataset.
-
Under Create impulse add a 'Spectral features' processing block, and a random ML block.
-
Open a command prompt or terminal window.
-
Initialize the block:
$ edge-impulse-blocks init --clean
-
Fetch new data via:
$ edge-impulse-blocks runner --download-data data/
-
Build the container:
$ docker build -t custom-ml-keras .
-
Run the container to test the script (you don't need to rebuild the container if you make changes):
macOS, Linux
$ docker run --rm -v $PWD:/app custom-ml-keras --data-directory /app/data --epochs 30 --learning-rate 0.01 --out-directory out/
Windows (Command prompt)
$ docker run --rm -v "%cd%":/app custom-ml-keras --data-directory /app/data --epochs 30 --learning-rate 0.01 --out-directory out/
Windows (Powershell)
$ docker run --rm -v ${PWD}$:/app custom-ml-keras --data-directory /app/data --epochs 30 --learning-rate 0.01 --out-directory out/
-
This creates a saved model ZIP file in the 'out' directory.
If you have extra packages that you want to install within the container, add them to requirements.txt
and rebuild the container.
To add new arguments, see Custom learning blocks > Arguments to your script.
To get up-to-date data from your project:
-
Install the Edge Impulse CLI v1.16 or higher.
-
Open a command prompt or terminal window.
-
Fetch new data via:
$ edge-impulse-blocks runner --download-data data/
You can also push this block back to Edge Impulse, that makes it available like any other ML block so you can retrain your model when new data comes in, or deploy the model to device. See Docs > Adding custom learning blocks for more information.
-
Push the block:
$ edge-impulse-blocks push
-
The block is now available under any of your projects via Create impulse > Add new learning block.
If you want to change the block type because you're classifying a different data type, or build a model with a different output format, run:
$ rm parameters.json .ei-block-config
$ edge-impulse-blocks init
And answer the wizard. This'll create a new parameters.json file.