Skip to content

Files

Latest commit

 

History

History
96 lines (74 loc) · 3.65 KB

README.md

File metadata and controls

96 lines (74 loc) · 3.65 KB

Using ONNX for Inference (YOLO2, VGG)

Convert YOLO2 and VGG models of PyTorch into ONNX format, and do inference by onnx-tensorflow or onnx-caffe2 backend. Also allow to visualize the model structure(.svg) and search matching substructure.  

GUI-demo

To open GUI interface, open terminal under this root folder and run below command line:

python GUI.py

Note: for Windows System, please download http://pjreddie.com/media/files/yolo.weights first and place this file and GUI.py in the same folder before you run above line  

Edit image path(can be local or URL) and select "model", "backend", and "device". Then press inference button. The inference result and time cost will be shown on screen.

Pressing `Model_Visualization` button will:
  • Show Model-related Parameters. (For now, only support the number of parameters and flops. ) 

  • Show Model Graph. Open a SVG image file throgth Web Browser. Zoom in/out to check the model structure.  

You can change the "SearchSeq" item and then press Search_Nodes button. It will search the whole graph and return a list of starting node indexes of matched sub-graph.  

 

API-demo

Python code:  

  • modelName is selected from ['yolo2', 'vgg11', 'vgg13', 'vgg16', 'vgg19']  
  • backend is selected from ['tensorflow', 'caffe2']  
  • device is selected from ["CPU" , "CUDA:0"]  
from Inference import Inference
a  =  Inference(modelName="yolo2", imgfile = './data/dog.jpg', backend="tensorflow", device="CUDA:0")
str_ = a.predict()

Using above python code to get prediction result (the returned string)

print (str_)

truck: 0.934710 bicycle: 0.998012 dog: 0.990524

for more detail [please refer this]

ONNX-IR Visualization (Optional)

Need to install pydot and graphviz first, and run command lines:

mkdir dot svg
python net_drawer.py --input "onnx/vgg19.onnx" --output "dot/vgg19.dot" --embed_docstring
dot -Tsvg "dot/vgg19.dot" -o "svg/vgg19.svg"

You can mark some specific nodes using --marked and --marked_list. For example, if you want to mark node 2,3 and 4, add --marked 1 --marked_list 2_3_4 after python net_drawer.py command.

python net_drawer.py --input "onnx/vgg19.onnx" --output "dot/vgg19.dot" --embed_docstring --marked 1 --marked_list 2_3_4

for more detail [please refer this]

Ref. Requirements & Develop Environment

  • python >= 2.7
  • pytorch >=0.2 and <= 0.3.0.post4 (v0.4.0 will Segmentation Error!, command "import onnx, torch" will fail)
  • onnx >= 1.2.1
  • tensorflow >= 1.6.0 and onnx-tf >= 1.1.2
  • caffe2 and onnx-caffe2 (optional, if you only use Tensorflow and won't use Caffe2 for inference)
  • numpy >= 1.14.2
  • pillow >= 5.0.0
  • pydot and graphviz (optional, for ONNX-IR Visualization)

Tutorials - Step by Step

Object Detection - YOLO2

Step 1 - Save YOLO model from PyTorch to ONNX

1.yolo2_pytorch_onnx_save_model.ipynb [Please refer this]

Step 2 - Load YOLO model from ONNX and Infer with Caffe2 or Tensorflow

2.yolo2_pytorch_onnx_load_model.ipynb [Please refer this]

Image Recognition - VGG

Save model from PyTorch to ONNX, Load model from ONNX, and Infer with Caffe2 or Tensorflow

3.vggnet_onnx.ipynb [Please refer this]