OpenVINO模型转换

将Paddle模型转换为OpenVINO的Inference Engine

环境依赖

  • Paddle2ONNX 0.4
  • ONNX 1.6.0+
  • PaddleX 1.3+
  • OpenVINO 2020.4+

说明:PaddleX安装请参考PaddleX , OpenVINO安装请参考OpenVINO,ONNX请安装1.6.0以上版本否则会出现转模型错误, Paddle2ONNX请安装0.4版本。注意:安装OpenVINO时请务必安装官网教程初始化OpenVINO运行环境,并安装相关依赖,否则会出现”No module named mo”等问题

请确保系统已经安装好上述基本软件,下面所有示例以工作目录 /root/projects/演示

导出inference模型

paddle模型转openvino之前需要先把paddle模型导出为inference格式模型,导出的模型将包括__model__、__params__和model.yml三个文件名,导出命令如下

paddlex --export_inference --model_dir=/path/to/paddle_model --save_dir=./inference_model --fixed_input_shape=[w,h]

注意:需要转OpenVINO模型时,导出inference模型请务必指定--fixed_input_shape参数来固定模型的输入大小,且模型的输入大小需要与训练时一致。 PaddleX客户端在发布模型时没有固定输入大小,因此对于可视化客户端,请找到任务所在目录,从里面的output文件夹找到best_model模型目录,将此目录使用如上命令进行固定shape导出即可。

导出OpenVINO模型

mkdir -p /root/projects
cd /root/projects
git clone https://github.com/PaddlePaddle/PaddleX.git
cd PaddleX
git checkout release/1.3
cd deploy/openvino/python

python converter.py --model_dir /path/to/inference_model --save_dir /path/to/openvino_model --fixed_input_shape [w,h]

转换成功后会在save_dir下出现后缀名为.xml、.bin、.mapping三个文件转换参数说明如下:

参数 说明
--model_dir Paddle模型路径,请确保__model__, __params__model.yml在同一个目录
--save_dir OpenVINO模型保存路径
--fixed_input_shape 模型输入的[W,H]
--data_type(option) (可选)FP32、FP16,默认为FP32,VPU下的IR需要为FP16

注意

  • 若转换过程中出现”No module named mo”的问题,请先初始化OpenVINO环境[./faq.md]再进行模型转换
  • 由于OpenVINO 从2021.1版本开始支持ONNX的resize-11 OP的原因,对于CPU部署请下载OpenVINO 2021.1+的版本
  • 由于VPU上不支持Range Layer,对于VPU部署请下载OpenVINO 2020.4版本进行模型转换
  • YOLOv3在通过OpenVINO部署时,由于OpenVINO对ONNX OP的支持限制,我们在将YOLOv3的Paddle模型导出时,对最后一层multiclass_nms进行了特殊处理,导出的ONNX模型,最终输出的Box结果包括背景类别(而Paddle模型不包含),此处在OpenVINO的部署代码中,我们通过后处理过滤了背景类别。