-
Notifications
You must be signed in to change notification settings - Fork 137
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add openvino interpreter samples #159
Changes from 1 commit
bd11660
adf7490
ec0a405
1021724
6cefbfd
5dc3744
fab3782
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -1,36 +1,43 @@ | ||||||
# OpenVINO Inference Interpreter | ||||||
Interpreter samples to parse OpenVINO inference outputs. | ||||||
# OpenVINO™ Inference Interpreter | ||||||
Interpreter samples to parse OpenVINO™ inference outputs. | ||||||
|
||||||
## Models supported from interpreter samples | ||||||
There are 5 SSD and 1 image classification interpreter samples. | ||||||
|
||||||
- 5 SSD interpreter samples support the following models. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
- Intel Pre-trained Models > Object Detection | ||||||
- [face-detection-0200](https://docs.openvinotoolkit.org/latest/omz_models_intel_face_detection_0200_description_face_detection_0200.html) | ||||||
- [face-detection-0202](https://docs.openvinotoolkit.org/latest/omz_models_intel_face_detection_0202_description_face_detection_0202.html) | ||||||
- [face-detection-0204](https://docs.openvinotoolkit.org/latest/omz_models_intel_face_detection_0204_description_face_detection_0204.html) | ||||||
- [person-detection-0200](https://docs.openvinotoolkit.org/latest/omz_models_intel_person_detection_0200_description_person_detection_0200.html) | ||||||
- [person-detection-0201](https://docs.openvinotoolkit.org/latest/omz_models_intel_person_detection_0201_description_person_detection_0201.html) | ||||||
- [person-detection-0202](https://docs.openvinotoolkit.org/latest/omz_models_intel_person_detection_0202_description_person_detection_0202.html) | ||||||
- [person-vehicle-bike-detection-2000](https://docs.openvinotoolkit.org/latest/omz_models_intel_person_vehicle_bike_detection_2000_description_person_vehicle_bike_detection_2000.html) | ||||||
- [person-vehicle-bike-detection-2001](https://docs.openvinotoolkit.org/latest/omz_models_intel_person_vehicle_bike_detection_2001_description_person_vehicle_bike_detection_2001.html) | ||||||
- [person-vehicle-bike-detection-2002](https://docs.openvinotoolkit.org/latest/omz_models_intel_person_vehicle_bike_detection_2002_description_person_vehicle_bike_detection_2002.html) | ||||||
- [vehicle-detection-0200](https://docs.openvinotoolkit.org/latest/omz_models_intel_vehicle_detection_0200_description_vehicle_detection_0200.html) | ||||||
- [vehicle-detection-0201](https://docs.openvinotoolkit.org/latest/omz_models_intel_vehicle_detection_0201_description_vehicle_detection_0201.html) | ||||||
- [vehicle-detection-0202](https://docs.openvinotoolkit.org/latest/omz_models_intel_vehicle_detection_0202_description_vehicle_detection_0202.html) | ||||||
|
||||||
- Public Pre-Trained Models(OMZ) > Object Detection | ||||||
- [ssd_mobilenet_v1_coco](https://docs.openvinotoolkit.org/latest/omz_models_public_ssd_mobilenet_v1_coco_ssd_mobilenet_v1_coco.html) | ||||||
- [ssd_mobilenet_v2_coco](https://docs.openvinotoolkit.org/latest/omz_models_public_ssd_mobilenet_v2_coco_ssd_mobilenet_v2_coco.html) | ||||||
|
||||||
- Intel Pre-trained Models | ||||||
- Object Detection | ||||||
- face-detection-0200 (https://docs.openvinotoolkit.org/latest/omz_models_intel_face_detection_0200_description_face_detection_0200.html) | ||||||
- face-detection-0202 (https://docs.openvinotoolkit.org/latest/omz_models_intel_face_detection_0202_description_face_detection_0202.html) | ||||||
- face-detection-0204 (https://docs.openvinotoolkit.org/latest/omz_models_intel_face_detection_0204_description_face_detection_0204.html) | ||||||
- person-detection-0200 (https://docs.openvinotoolkit.org/latest/omz_models_intel_person_detection_0200_description_person_detection_0200.html) | ||||||
- person-detection-0201 (https://docs.openvinotoolkit.org/latest/omz_models_intel_person_detection_0201_description_person_detection_0201.html) | ||||||
- person-detection-0202 (https://docs.openvinotoolkit.org/latest/omz_models_intel_person_detection_0202_description_person_detection_0202.html) | ||||||
- person-vehicle-bike-detection-2000 (https://docs.openvinotoolkit.org/latest/omz_models_intel_person_vehicle_bike_detection_2000_description_person_vehicle_bike_detection_2000.html) | ||||||
- person-vehicle-bike-detection-2001 (https://docs.openvinotoolkit.org/latest/omz_models_intel_person_vehicle_bike_detection_2001_description_person_vehicle_bike_detection_2001.html) | ||||||
- person-vehicle-bike-detection-2002 (https://docs.openvinotoolkit.org/latest/omz_models_intel_person_vehicle_bike_detection_2002_description_person_vehicle_bike_detection_2002.html) | ||||||
- vehicle-detection-0200 (https://docs.openvinotoolkit.org/latest/omz_models_intel_vehicle_detection_0200_description_vehicle_detection_0200.html) | ||||||
- vehicle-detection-0201 (https://docs.openvinotoolkit.org/latest/omz_models_intel_vehicle_detection_0201_description_vehicle_detection_0201.html) | ||||||
- vehicle-detection-0202 (https://docs.openvinotoolkit.org/latest/omz_models_intel_vehicle_detection_0202_description_vehicle_detection_0202.html) | ||||||
- Image classification interpreter sample supports the following model. | ||||||
- Public Pre-Trained Models(OMZ) > Classification | ||||||
- [mobilenet-v2-pytorch](https://docs.openvinotoolkit.org/latest/omz_models_public_mobilenet_v2_pytorch_mobilenet_v2_pytorch.html) | ||||||
|
||||||
- Public Pre-Trained Models(OMZ) | ||||||
- Classification | ||||||
- mobilenet-v2-pytorch (https://docs.openvinotoolkit.org/latest/omz_models_public_mobilenet_v2_pytorch_mobilenet_v2_pytorch.html) | ||||||
You can find more OpenVINO™ Trained Models [here](https://docs.openvinotoolkit.org/latest/omz_models_intel_index.html) | ||||||
To run the inference with OpenVINO™, the model format should be Intermediate Representation(IR). | ||||||
For the Caffe/TensorFlow/MXNet/Kaldi/ONNX models, please see the [Model Conversion Instruction](https://docs.openvinotoolkit.org/latest/openvino_docs_MO_DG_prepare_model_convert_model_Converting_Model.html) | ||||||
|
||||||
- Object Detection | ||||||
- ssd_mobilenet_v1_coco (https://docs.openvinotoolkit.org/latest/omz_models_public_ssd_mobilenet_v1_coco_ssd_mobilenet_v1_coco.html) | ||||||
- ssd_mobilenet_v2_coco (https://docs.openvinotoolkit.org/latest/omz_models_public_ssd_mobilenet_v2_coco_ssd_mobilenet_v2_coco.html) | ||||||
You need to implement your own interpreter samples to support the other OpenVINO™ Trained Models. | ||||||
|
||||||
## Model download | ||||||
- Prerequisites | ||||||
- OpenVINO (To install OpenVINO, please see https://docs.openvinotoolkit.org/latest/openvino_docs_install_guides_installing_openvino_linux.html) | ||||||
- OpenVINO models (To download OpenVINO models, please go https://docs.openvinotoolkit.org/latest/omz_tools_downloader_README.html) | ||||||
- VOCdevkit dataset (To download VOC2012 dataset, please go http://host.robots.ox.ac.uk/pascal/VOC/voc2012/#devkit) | ||||||
- OpenVINO™ (To install OpenVINO™, please see the [OpenVINO™ Installation Instruction](https://docs.openvinotoolkit.org/latest/openvino_docs_install_guides_installing_openvino_linux.html) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
- OpenVINO™ models (To download OpenVINO™ models, please see the [Model Downloader Instruction] https://docs.openvinotoolkit.org/latest/omz_tools_downloader_README.html) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Missing )
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
- PASCAL VOC 2012 dataset (To download VOC 2012 dataset, please go [VOC2012 download](http://host.robots.ox.ac.uk/pascal/VOC/voc2012/#devkit) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Missing )
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
|
||||||
```bash | ||||||
# cd <openvino_dir>/deployment_tools/open_model_zoo/tools/downloader | ||||||
|
@@ -43,30 +50,31 @@ Interpreter samples to parse OpenVINO inference outputs. | |||||
|
||||||
## Model inference | ||||||
- Prerequisites: | ||||||
- Put the models downloaded in <datumaro_root_dir>/datumaro/plugins/openvino/models | ||||||
- Put the VOCdevkit dataset downloaded in <datumaro_root_dir> | ||||||
- OpenVINO™ (To install OpenVINO™, please see the [OpenVINO™ Installation Instruction](https://docs.openvinotoolkit.org/latest/openvino_docs_install_guides_installing_openvino_linux.html) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Missing ) (+3 next)
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
- Datumaro (To install Datumaro, please see the [User Manual](docs/user_manual.md) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
- OpenVINO™ models (To download OpenVINO™ models, please see the [Model Downloader Instruction] https://docs.openvinotoolkit.org/latest/omz_tools_downloader_README.html) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
- PASCAL VOC 2012 dataset (To download VOC 2012 dataset, please go [VOC2012 download](http://host.robots.ox.ac.uk/pascal/VOC/voc2012/#devkit) | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
|
||||||
- To run the inference with OpenVINO models and the interpreter samples, please follow the instructions below. | ||||||
- To run the inference with OpenVINO™ models and the interpreter samples, please follow the instructions below. | ||||||
|
||||||
```bash | ||||||
# . <openvino_dir>/bin/setupvars.sh | ||||||
# cd <datumaro_root_dir>/datumaro/plugins/openvino/ | ||||||
# <openvino_dir>/bin/setupvars.sh | ||||||
# datum create -o <proj_dir> | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why these commands have different indents? |
||||||
# datum model add -l <launcher> -p <proj_dir> --copy -- -d <path_to_xml> -w <path_to_bin> -i <path_to_interpreter_script> | ||||||
# datum add path -p <proj_dir> -f <format> <path_to_dataset> | ||||||
# datum model run -p <proj_dir> -m model-0 | ||||||
# | ||||||
# Examples | ||||||
# Detection> ssd_mobilenet_v2_coco | ||||||
. /opt/intel/openvino_2021/bin/setupvars.sh | ||||||
/opt/intel/openvino_2021/bin/setupvars.sh | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If we install openvino 2021.r1, the default path is /opt/intel/openvino_2021, not /opt/intel/openvino. The default path like openvino_2021 had been using since openvino 2021.r1. Do you still want me to change it? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I changed it to openvino because we don't know user which Openvino version will install. openvino is more general. So I changed it. |
||||||
cd /home/cvalgo/workspace/datumaro/datumaro/plugins/openvino/ | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please clean There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||
datum create -o proj_ssd_mobilenet_v2_coco_detection | ||||||
datum model add -l openvino -p proj_ssd_mobilenet_v2_coco_detection --copy -- --output-layers=do_ExpandDims_conf/sigmoid -d model/ssd_mobilenet_v2_coco.xml -w model/ssd_mobilenet_v2_coco.bin -i samples/ssd_mobilenet_coco_detection_interp.py | ||||||
datum add path -p proj_ssd_mobilenet_v2_coco_detection -f voc /home/cvalgo/workspace/datumaro/VOCdevkit | ||||||
datum model run -p proj_ssd_mobilenet_v2_coco_detection -m model-0 | ||||||
|
||||||
# Classification> mobilenet-v2-pytorch | ||||||
. /opt/intel/openvino_2021/bin/setupvars.sh | ||||||
/opt/intel/openvino_2021/bin/setupvars.sh | ||||||
cd /home/cvalgo/workspace/datumaro/datumaro/plugins/openvino/ | ||||||
datum create -o proj_mobilenet_v2_classification | ||||||
datum model add -l openvino -p proj_mobilenet_v2_classification --copy -- -d model/mobilenet-v2-pytorch.xml -w model/mobilenet-v2-pytorch.bin -i samples/mobilenet_v2_pytorch_interp.py | ||||||
|
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
@@ -65,19 +65,7 @@ def process_outputs(inputs, outputs): | |||||||||
w = min(int(det[5] * input_width - x), input_width) | ||||||||||
h = min(int(det[6] * input_height - y), input_height) | ||||||||||
|
||||||||||
image_results.append( | ||||||||||
Bbox( | ||||||||||
x, | ||||||||||
y, | ||||||||||
w, | ||||||||||
h, | ||||||||||
label=label, | ||||||||||
attributes={ | ||||||||||
"confidence": conf, | ||||||||||
"confidences": list(map(float, det_confs)), | ||||||||||
}, | ||||||||||
) | ||||||||||
) | ||||||||||
image_results.append(Bbox(x, y, w, h, label=label, attributes={"score": conf, "scores": list(map(float, det_confs)),},)) | ||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||||||
|
||||||||||
results.append(image_results) | ||||||||||
|
||||||||||
|
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
@@ -68,19 +68,7 @@ def process_outputs(inputs, outputs): | |||||||||
w = min(int(det[5] * input_width - x), input_width) | ||||||||||
h = min(int(det[6] * input_height - y), input_height) | ||||||||||
|
||||||||||
image_results.append( | ||||||||||
Bbox( | ||||||||||
x, | ||||||||||
y, | ||||||||||
w, | ||||||||||
h, | ||||||||||
label=label, | ||||||||||
attributes={ | ||||||||||
"confidence": conf, | ||||||||||
"confidences": list(map(float, det_confs)), | ||||||||||
}, | ||||||||||
) | ||||||||||
) | ||||||||||
image_results.append(Bbox(x, y, w, h, label=label, attributes={"score": conf, "scores": list(map(float, det_confs)),},)) | ||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||||||
|
||||||||||
results.append(image_results) | ||||||||||
|
||||||||||
|
@@ -92,9 +80,7 @@ def get_categories(): | |||||||||
|
||||||||||
label_categories = LabelCategories() | ||||||||||
|
||||||||||
with open( | ||||||||||
"samples/coco.class", "r" | ||||||||||
) as file: | ||||||||||
with open("samples/coco.class", "r") as file: | ||||||||||
for line in file.readlines(): | ||||||||||
label = line.strip() | ||||||||||
label_categories.add(label) | ||||||||||
|
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
@@ -65,19 +65,7 @@ def process_outputs(inputs, outputs): | |||||||||
w = min(int(det[5] * input_width - x), input_width) | ||||||||||
h = min(int(det[6] * input_height - y), input_height) | ||||||||||
|
||||||||||
image_results.append( | ||||||||||
Bbox( | ||||||||||
x, | ||||||||||
y, | ||||||||||
w, | ||||||||||
h, | ||||||||||
label=label, | ||||||||||
attributes={ | ||||||||||
"confidence": conf, | ||||||||||
"confidences": list(map(float, det_confs)), | ||||||||||
}, | ||||||||||
) | ||||||||||
) | ||||||||||
image_results.append(Bbox(x, y, w, h, label=label, attributes={"score": conf, "scores": list(map(float, det_confs)),},)) | ||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||||||
|
||||||||||
results.append(image_results) | ||||||||||
|
||||||||||
|
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
@@ -65,19 +65,7 @@ def process_outputs(inputs, outputs): | |||||||||
w = min(int(det[5] * input_width - x), input_width) | ||||||||||
h = min(int(det[6] * input_height - y), input_height) | ||||||||||
|
||||||||||
image_results.append( | ||||||||||
Bbox( | ||||||||||
x, | ||||||||||
y, | ||||||||||
w, | ||||||||||
h, | ||||||||||
label=label, | ||||||||||
attributes={ | ||||||||||
"confidence": conf, | ||||||||||
"confidences": list(map(float, det_confs)), | ||||||||||
}, | ||||||||||
) | ||||||||||
) | ||||||||||
image_results.append(Bbox(x, y, w, h, label=label, attributes={"score": conf, "scores": list(map(float, det_confs)),},)) | ||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||||||
|
||||||||||
results.append(image_results) | ||||||||||
|
||||||||||
|
Original file line number | Diff line number | Diff line change | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
@@ -65,19 +65,7 @@ def process_outputs(inputs, outputs): | |||||||||
w = min(int(det[5] * input_width - x), input_width) | ||||||||||
h = min(int(det[6] * input_height - y), input_height) | ||||||||||
|
||||||||||
image_results.append( | ||||||||||
Bbox( | ||||||||||
x, | ||||||||||
y, | ||||||||||
w, | ||||||||||
h, | ||||||||||
label=label, | ||||||||||
attributes={ | ||||||||||
"confidence": conf, | ||||||||||
"confidences": list(map(float, det_confs)), | ||||||||||
}, | ||||||||||
) | ||||||||||
) | ||||||||||
image_results.append(Bbox(x, y, w, h, label=label, attributes={"score": conf, "scores": list(map(float, det_confs)),},)) | ||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done |
||||||||||
|
||||||||||
results.append(image_results) | ||||||||||
|
||||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done