PyeIQ is written on top of eIQ™ ML Software Development Environment and provides a set of Python classes allowing the user to run Machine Learning applications in a simplified and efficiently way without spending time on cross-compilations, deployments or reading extensive guides.
Now PyeIQ 3.0.x release is announced. This release is based on i.MX Linux BSP 5.4.70_2.3.0 & 5.4.70_2.3.2(8QM, 8M Plus) and can also work on i.MX Linux BSP 5.10.9_1.0.0 & 5.10.35_2.0.0 & 5.10.52_2.1.0. And also, in latest PyeIQ 3.1.0 release, BSP 5.10.72_2.2.0 is also added into supported list.
This article is a simple guide for users. For further questions, please post a comment on eIQ Community or just below this article.
*PyeIQ has no test and maintaining plan on BSP 5.15 and later version. We recommend customers to refer to NXP gopoint (formerly known as NXP Demo Experience) for more ML demos on BSP 5.15 and later version. You can find more details in this link.
BSP Release | PyeIQ Release | PyeIQ Updates | Board | Date | Status | Notes |
Apr, 2020 | PoC | |||||
May, 2020 | ||||||
Jun, 2020 | Stable | |||||
Jun, 2020 | ||||||
Aug, 2020 | ||||||
Nov, 2020 | ||||||
Jul, 2021 | Stable | |||||
Sep, 2021 | ||||||
Dec, 2021 | ||||||
Dec, 2021 |
*Release v3.0.x can also work on i.MX Linux BSP 5.10.9_1.0.0 & 5.10.35_2.0.0 & 5.10.52_2.1.0. And Release v3.1.0 works on 5.10.72_2.2.0. Reasons and details will be discussed at the end of guide.
3.1.0
3.0.0
2.0.0
1.0.0
Copyright 2021 NXP Semiconductors. Free use of this software is granted under the terms of the BSD 3-Clause License. Source code can be found on CodeAurora. See LICENSE for details.
Use pip3 tool to install the package located at PyPI repository:
# pip3 install pyeiq
* PyeIQ v1 and v2 can be installed with "pip3 install eiq". For more details, please check PyPI - eiq.
PyeIQ can be installed with offline tarballs as well:
# pip3 install <tarball>
Here list some available tarballs of main versions:
PyeIQ Version | Download Link |
eiq-1.0.0.tar.gz | |
eiq-2.0.0.tar.gz | |
pyeiq-3.0.0.tar.gz |
More other versions can be found and downloaded from PyPI - eiq and PyPI - pyeiq.
The PyeIQ installation generates a tool manager called pyeiq. This tool can be used to run the demos and applications, specify parameters, get info and more.
To start the manager tool:
# pyeiq
The above command returns the PyeIQ manager tool options:
Manager Tool Command | Descrption | Example |
pyeiq --list-apps | List the available applications. | |
pyeiq --list-demos | List the available demos. | |
pyeiq --run <app_name/demo_name> | Run the application or demo. | # pyeiq --run switch_image |
pyeiq --info <app_name/demo_name> | Application or demo short description and usage. | # pyeiq --info object_detection_tflite |
pyeiq --clear-cache | Clear cached media generated by demos. |
PyeIQ requires a network connection to retrieve the required model & media package.
Applications: Switch Classification Image(switch_image), Switch Detection Video(switch_video)
Demos: Covid19 Detection(covid19_detection), Object Classification(object_classification_tflite), Object Detection(object_detection_tflite)
Parameter | Description | Example of usage |
-d / --download |
Chooses from which server the model & media package are going to be downloaded. Options: drive, github, wget. Default: wget. |
# pyeiq --run <demo name> --download drive |
-i / --image | Run the demo on an image of your choice. Default: Use the image in model & media package downloaded. | # pyeiq --run <demo name> --image <root to image>/<image name> |
-l / --labels | Uses a labels file of your choice within the demo. Labels and models must be compatible for proper outputs. Default: Use default label file in model & media package downloaded. | # pyeiq --run <demo name> --labels <root to label file>/<label file name> |
-m / --model | Uses a model file of your choice within the demo. Default: Use default model file in model & media package downloaded. | # pyeiq --run <demo name> --model <root to model file>/<model file name> |
-r / --res | Choose the resolution of your video capture device. Options: full_hd (1920x1080), hd (1280x720), vga (640x480). Default: hd if supported, otherwise uses the best one available. | # pyeiq --run <demo name> --res vga |
-f / --video_fwk | Choose which framework is used to display the video. Options: opencv, v4l2, gstreamer (experimental). Default: v4l2. | # pyeiq --run <demo name> --video_fwk v4l2 |
-v / --video_src | Run inference in videos. Videos can be from a video capture device or a video file. Options: True (Find a video capture device automatically), /dev/video<x>, <path to video file>. |
# pyeiq --run <demo name> --video_src True # pyeiq --run <demo name> --video_src /dev/video1 # pyeiq --run <demo name> --video_src <path to video file>/<video file name> |
-c / --camera_params | (Only used in demo covid19 detection.) Choose eye height, eye angle and eye slope for camera. Options: None or "<num> <num> <num>". Default: "200 60 60" | # pyeiq --run covid19_detection --camera_params "200 60 60" |
-w / --work_mode | (Only used in demo covid19 detection.) Choose work mode for demo. Options: 0 (Only detect facemask), 1 (Detect both facemask and social distance). Default: 0. | # pyeiq --run covid19_detection --work_mode 1 |
Multiple parameters can be used at once. For example,
# pyeiq --run <demo name> --download github --video_src True --res vga --video_fwk v4l2
This application offers a graphical interface for users to run an object classification demo using either CPU or GPU/NPU to perform inference on a list of available images.
This application uses:
More details on eIQ™ page.
# pyeiq --run switch_image
CPU:
GPU/NPU:
This application offers a graphical interface for users to run an object detection demo using either CPU or GPU/NPU to perform inference on a video file.
This application uses:
More details on eIQ™ page.
# pyeiq --run switch_video
Object detection is a computer technology related to computer vision and image processing that deals with detecting instances of semantic objects of a certain class (such as humans, buildings, or cars) in digital images and videos. Well-researched domains of object detection include face detection and pedestrian detection. Object detection has applications in many areas of computer vision, including image retrieval and video surveillance.
This demo uses:
More details on eIQ™ page.
Run the Object Detection demo using the following line:
# pyeiq --run object_detection_tflite
Pass any image as an argument:
# pyeiq --run object_detection_tflite --image=/path_to_the_image
Run the Object Detection using the following line:
# pyeiq --run object_detection_tflite --video_src=/path_to_the_video
Specify the camera device:
# pyeiq --run object_detection_tflite --video_src=/dev/video<index>
Object Classification is the problem of identifying to which of a set of categories a new observation belongs, on the basis of a training set of data containing observations whose category membership is known. Examples are assigning a given email to the "spam" or "non-spam" class, and assigning a diagnosis to a given patient based on observed characteristics of the patient.
This demo uses:
MobileNet as default algorithm.
More details on eIQ™ page.
Run the Object Classification demo using the following line:
# pyeiq --run object_classification_tflite
Pass any image as an argument:
# pyeiq --run object_classification_tflite --image=/path_to_the_image
Run the Object Classification using the following line:
# pyeiq --run object_classification_tflite --video_src=/path_to_the_video
Specify the camera device:
# pyeiq --run object_classification_tflite --video_src=/dev/video<index>
Covid19 Detection is a demo which can detect whether people are wearing masks or not. It can be used to detect the social distance among people as well.
This demo uses:
More details on eIQ™ page.
Run the Covid19 Detection demo using the following line:
# pyeiq --run covid19_detection
Pass any image as an argument:
# pyeiq --run covid19_detection --image=/path_to_the_image
Run the Covid19 Detection using the following line:
# pyeiq --run covid19_detection --video_src=/path_to_the_video
Specify the camera device:
# pyeiq --run covid19_detection --video_src=/dev/video<index>
PyeIQ v3.0.x release is based on i.MX Linux BSP 5.4.70. However, in most cases, it can also work on BSP 5.10.x, including BSP 5.10.9, 5.10.35, 5.10.52 and 5.10.72.
In PyeIQ v3.0.0 and v3.0.1, one known issue about BSP 5.10.x support is about application Switch Detection Video(switch_video). Due to different versions of Opencv on BSP 5.4.70 and 5.10.x, app Switch Detection Video may occur problems during operation.
The expected error message is like this:
/home/root/.cache/eiq/eIQVideoSwitchCore/bin/video_switch_core: error while loading shared libraries: libopencv_objdetect.so.4.4: cannot open shared object file: No such file or directory
To solve this problem, one temporary solution is provided:
One pre-built video_switch_core for 5.10.9 and 5.10.35 BSP(which use tflite lib 2.4.1), one pre-built video_switch_core for 5.10.52 BSP(which use tflite lib 2.5.0) and one pre-built video_switch_core for 5.10.72 BSP(which use tflite lib 2.6.0) can be downloaded here. Use these newly downloaded cores to replace the core in model & media package downloaded by PyeIQ. The old core is located in:
/home/root/.cache/eiq/eIQVideoSwitchCore/bin
After replacement, run app Switch Detection Video(switch_video) again.
In PyeIQ v3.0.2 and v3.1.0, this issue is fixed. PyeIQ now will build the binary which fits BSP environemnt first before running inference. So we recommend users to use PyeIQ of these two versions now.
Another issue is about new feature in BSP 5.10.72. From this version, i.MX Linux BSP supports VX delegate and will gradually give up NNAPI delegate support in furture version. So we provide two different versions of PyeIQ in 2021Q4 release. v3.0.2 is for users who use BSP 5.10.52 and other previous BSP. It continues supporting NNAPI. v3.1.0 is for users who use BSP 5.10.72 and other furture BSP. It supports VX delegate.
To download different versions of PyeIQ, users need to state it when using pip install. For example, the commands used are shown as below:
# pip3 install pyeiq==3.0.2
or
# pip3 install pyeiq==3.1.0
Other previous versions can also be installed in this way. Please choose the version which fits your BSP version.
*If users meet any network problems when installing PyeIQ with pip, users can try command shown as below:
pip3 install --trusted-host pypi.org --trusted-host files.pythonhosted.org pyeiq
or download tar.gz package from pypi and install it offline.
For further questions, please post a comment on eIQ Community or just below this article.
ここにコメントを追加するには、ご登録いただく必要があります。 ご登録済みの場合は、ログインしてください。 ご登録がまだの場合は、ご登録後にログインしてください。