Reference implementation for deploying ONNX Models to Intel OpenVINO based devices with ONNX Runtime and Azure IoT Edge
In this tutorial, you will learn how to deploy an ONNX Model to an IoT Edge device based on Intel platform, using ONNX Runtime for HW acceleration of the AI model. By completing this tutorial, you will have a low-cost DIY solution for object detection within a space and a unique understanding of integrating ONNX Runtime with Azure IoT services and machine learning.
Setup Azure account and Visual Studio enviroment or skip to Model deployment if you already have the setup to work with Visual Studio and Azure services.
This phase will help you to setup the UP2 device for using with this tutorial. Equipment needed for this setup are:
- UP2 AI Vision Kit (make sure that you are using the version B kit with Myriad X option)
- A USB mouse and USB keyboard
- Ethernet (cat 6) cable or the WiFI Kit for the UP2
- A monitor with HDMI or Display Port (DP) interface
Configure the Neural Compute Stick in the UP2 device using these steps.
sudo usermod -a -G users "$(whoami)"
sudo cp /opt/intel/openvino/inference_engine/external/97-myriad-usbboot.rules /etc/udev/rules.d/
sudo udevadm control --reload-rules
sudo udevadm trigger
sudo ldconfig
To display the inference output on the local display, add xhost + to the /home/$user/.profile
file.
Confirm that the webcam is connected to one of the USB ports. Default for the first camera is /dev/video0
. Confirm that the file ./CameraCaptureModule/camerainfo.csv
has the entry for the device.
This part focuses on deploying an object detection model on your IoT Edge device using a pretrained model from the ONNX model zoo.
- Clone this repo to your local drive / computer.
-
If using a different desktop PC for VS Code, you must login to your registry created in this step. To do this, ensure that the Docker application is running on your desktop and that you are signed in. To sign in, using the Terminal of VS Code, run the command in the terminal of VS code:
docker login -u <username> -p <password> <registry_address>
-
You should see a 'Login Succeeded' message.
-
On your computer, open the folder for this repo in VS Code.
-
Note: If you downloaded as a zip file, there may be two onnxruntime-iot-edge-master folders when you unzip, one nested in the other. Open the INNER one
-
Select View > Command Palette to open the VS Code command palette.
-
In the command palette, enter and run the command Azure: Sign in and follow the instructions to sign into your Azure account.
-
Open the .env file and replace username, password and login server for the CONTAINER_REGISTRY variables with the credentials of the container registry that was set up in this step.
-
In the .env file replace the Storage account name and access key with the details of your Azure Storage account details.
-
Fill in the .env file so that it now looks something like this:
CONTAINER_REGISTRY_USERNAME="<_username_>" CONTAINER_REGISTRY_PASSWORD="<_password_>" CONTAINER_REGISTRY_ADDRESS="<_Login server_>" MY_STORAGE_ACCOUNT_NAME="<_Storage account name_>" MY_STORAGE_ACCOUNT_KEY="<_access key_>" MY_STORAGE_CONNECTION_STRING="<_storage connection string_>"
- In the CameraCaptureModule directory, edit the file camerainfo.csv so that each line holds the camera number and the name of the camera delimited with a ','. The current csv is set for a camera with the name cam1 and camera number 0.
-
-
Within the InferenceModule directory, main.py is the file in which blob storage is set up as well. By default, we are going to use blob storage and we have created the necessary resources for it. If you do not wish to use it, change the variable CLOUD_STORAGE to False.
-
In the .env file update the MY_STORAGE_ACCOUNT_NAME, MY_STORAGE_ACCOUNT_KEY and MY_STORAGE_CONNECTION_STRING entries with the details of your Azure Storage account details.
-
You can find the Storage account name, access key and Connection string on the Azure portal in your storage account under the Access Keys tab.
-
In the InferenceModule directory, in main.py adjust the variable block_blob_service to hold the connection string to the local blob storage account. You can find information about configuring connection strings here or just replace the given
< >
with what is required. -
Run
sudo mkdir /home/storagedata
in the SSH terminal.
After these steps the .env file should have the following variables with the appropriate values for your account:
```
CONTAINER_REGISTRY_USERNAME="<username>"
CONTAINER_REGISTRY_PASSWORD="<password>"
CONTAINER_REGISTRY_ADDRESS="<Login server>"
MY_STORAGE_ACCOUNT_NAME="<Storage account name>"
MY_STORAGE_ACCOUNT_KEY="<access key>"
MY_STORAGE_CONNECTION_STRING="<Connection string>"
```
-
In .vscode/settings.json replace arm64 with amd64.
-
Copy deployment-amd64.template.json to deployment.template.json
-
Right click on deployment.template.json, then select Build and Push IoT Edge Solution. Behind the scenes, this runs two docker commands. One to build your container and another to push that to the container registry. This step may take some time (15 minutes) * Note: Every time changes are made and you want to re-deploy the modules the version of the module must be incremented or changed. In module.json change the version number before selecting Build and Push IoT Edge Solution.
-
At the bottom left corner of VS Code, you should see a drop-down menu labeled AZURE IOT HUB. Expand it and select IoT Hub. Follow the prompts that appear in the command palette at the top and select the IoT Hub you created.
-
After selecting the hub, click on the Devices drop down menu. You should be able to see your device like this:
-
Right click on the device and select Create Deployment for Single Device. This will open a File Explorer window. Navigate into the config folder and select the deployment.amd64.json file.
-
You can verify that the PreModule and InferenceModules are running by typing the command
sudo iotedge list
on the IoT Edge device terminal. It should yield something like this (your module versions may be different): -
To view the output of the model in VS Code, select on the device in the Azure IoT Hub device menu and select Start Monitoring Built-in Event Endpoint. Your terminal should look like this:
- You should be able to see the output. You can select on the lock icon in the top right corner to lock the toggle at the bottom of the terminal window; now you can see the output in real time:
-
Once your modules are up and running on your Iot Edge device, you should be able to see inference outputs on the portal in your storage account!
-
Go to your storage account and select the Blobs tab.
-
There should be a storage container called storagetest. Select it and you will see your results stored as blobs!
-
To see what's in a blob, select it and then select Edit Blob
-
The output being displayed only shows the labels and confidence scores for objects above a threshold confidence score.
-
The output of the TinyYOLO model contains more information such as the confidence scores for each of the 20 labels and the coordinates of the detected objects in the frame. If you would like to see this additional information, feel free to modify the Inference Python file in the ARM64_EdgeSolution.
If you don't see your module as 'Running':
-
Run
sudo journalctl -u iotedge -f
and see if the image is being pulled. -
If you do not see any modules running, restart iotedge with
systemctl restart iotedge
, then check again.
For further debugging, you can try these commands:
-
Run
sudo systemctl status iotedge
to view the status of the IoT Edge Security Manager. -
Run
sudo journalctl -u iotedge -f
to view the logs of the IoT Edge Security Manager. -
Run
sudo docker logs <module name>
to view specific error logs for a module
For more help on troubleshooting Azure IoT Edge, go here.
This step focuses on visualizing the data being gathered by the model and stored in Azure Blob Storage using Power BI to display.
For help troubleshooting on Power BI, please visit Power BI's documentation site to learn more.
For technical help, please visit Power BI's support page.
Here are some ideas about how to continue your project
-
Deploy your own model!
- Check out ONNX's pre-made model zoo here for models to download and deploy.
- Create your own model using Azure Machine Learning or Custom Vision.
-
Create a dashboard for your Power BI report by following this tutorial.