ONNX Runtime is a cross-platform inferencing and training accelerator compatible with many popular ML/DNN frameworks. Check its github for more information.
ONNX stands for Open Neural Network Exchange, which acts as Intermediate Representation(IR) for ML/DNN models from many frameworks. Check its github for more information.
- To verify the correctness of exported ONNX models in ONNX Runtime.
- To ease the deployment of ONNX models with custom operators from
mmcv.ops
in ONNX Runtime.
Operator | CPU | GPU | Note |
---|---|---|---|
SoftNMS | Y | N | commit 94810f |
RoiAlign | Y | N | None |
Please be noted that only onnxruntime>=1.5.1 of CPU version on Linux platform is tested by now.
- Clone repository
git clone https://github.com/open-mmlab/mmcv.git
- Download
onnxruntime-linux-x64-1.5.1.tgz
from ONNX Runtime releases, extract it, exposeONNXRUNTIME_DIR
and finally add the lib path toLD_LIBRARY_PATH
as below:
wget https://github.com/microsoft/onnxruntime/releases/download/v1.5.1/onnxruntime-linux-x64-1.5.1.tgz
tar -zxvf onnxruntime-linux-x64-1.5.1.tgz
cd onnxruntime-linux-x64-1.5.1
export ONNXRUNTIME_DIR=$(pwd)
export LD_LIBRARY_PATH=$ONNXRUNTIME_DIR/lib:$LD_LIBRARY_PATH
cd mmcv # to MMCV root directory
MMCV_WITH_OPS=1 MMCV_WITH_ORT=1 pip install -e .
Install ONNX Runtime with pip
pip install onnxruntime==1.5.1
Inference Demo
import os
import numpy as np
import onnxruntime as ort
from mmcv.ops import get_onnxruntime_op_path
ort_custom_op_path = get_onnxruntime_op_path()
assert os.path.exists(ort_custom_op_path)
session_options = ort.SessionOptions()
session_options.register_custom_ops_library(ort_custom_op_path)
# exported ONNX model with custom operators
onnx_file = 'sample.onnx'
input_data = np.random.randn(1, 3, 224, 224).astype(np.float32)
sess = ort.InferenceSession(onnx_file, session_options)
onnx_results = sess.run(None, {'input' : input_data})
- The custom operator is not included in supported operator list in ONNX Runtime.
- The custom operator should be able to be exported to ONNX.
Take custom operator soft_nms
for example.
-
Add header
soft_nms.h
to ONNX Runtime include directorymmcv/ops/csrc/onnxruntime/
-
Add source
soft_nms.cpp
to ONNX Runtime source directorymmcv/ops/csrc/onnxruntime/cpu/
-
Register
soft_nms
operator in onnxruntime_register.cpp#include "soft_nms.h" SoftNmsOp c_SoftNmsOp; if (auto status = ortApi->CustomOpDomain_Add(domain, &c_SoftNmsOp)) { return status; }
-
Add unit test into
tests/test_ops/test_onnx.py
Check here for examples.
Finally, welcome to send us PR of adding custom operators for ONNX Runtime in MMCV. 🤓
- None