# 视频实时人像分割模型Linux平台C++预测部署 ## 1. 系统和软件依赖 ### 1.1 操作系统及硬件要求 - Ubuntu 14.04 或者 16.04 (其它平台未测试) - GCC版本4.8.5 ~ 4.9.2 - 支持Intel MKL-DNN的CPU - NOTE: 如需在Nvidia GPU运行,请自行安装CUDA 9.0 / 10.0 + CUDNN 7.3+ (不支持9.1/10.1版本的CUDA) ### 1.2 下载PaddlePaddle C++预测库 PaddlePaddle C++ 预测库主要分为CPU版本和GPU版本。 其中,GPU 版本支持`CUDA 10.0` 和 `CUDA 9.0`: 以下为各版本C++预测库的下载链接: | 版本 | 链接 | | ---- | ---- | | CPU+MKL版 | [fluid_inference.tgz](https://paddle-inference-lib.bj.bcebos.com/1.6.3-cpu-avx-mkl/fluid_inference.tgz) | | CUDA9.0+MKL 版 | [fluid_inference.tgz](https://paddle-inference-lib.bj.bcebos.com/1.6.3-gpu-cuda9-cudnn7-avx-mkl/fluid_inference.tgz) | | CUDA10.0+MKL 版 | [fluid_inference.tgz](https://paddle-inference-lib.bj.bcebos.com/1.6.3-gpu-cuda10-cudnn7-avx-mkl/fluid_inference.tgz) | 更多可用预测库版本,请点击以下链接下载:[C++预测库下载列表](https://paddlepaddle.org.cn/documentation/docs/zh/advanced_usage/deploy/inference/build_and_install_lib_cn.html) 下载并解压, 解压后的 `fluid_inference`目录包含的内容: ``` fluid_inference ├── paddle # paddle核心库和头文件 | ├── third_party # 第三方依赖库和头文件 | └── version.txt # 版本和编译信息 ``` **注意:** 请把解压后的目录放到合适的路径,**该目录路径后续会作为编译依赖**使用。 ## 2. 编译与运行 ### 2.1 配置编译脚本 打开文件`linux_build.sh`, 看到以下内容: ```shell # 是否使用GPU WITH_GPU=OFF # Paddle 预测库路径 PADDLE_DIR=/PATH/TO/fluid_inference/ # CUDA库路径, 仅 WITH_GPU=ON 时设置 CUDA_LIB=/PATH/TO/CUDA_LIB64/ # CUDNN库路径,仅 WITH_GPU=ON 且 CUDA_LIB有效时设置 CUDNN_LIB=/PATH/TO/CUDNN_LIB64/ # OpenCV 库路径, 无须设置 OPENCV_DIR=/PATH/TO/opencv3gcc4.8/ cd build cmake .. \ -DWITH_GPU=${WITH_GPU} \ -DPADDLE_DIR=${PADDLE_DIR} \ -DCUDA_LIB=${CUDA_LIB} \ -DCUDNN_LIB=${CUDNN_LIB} \ -DOPENCV_DIR=${OPENCV_DIR} \ -DWITH_STATIC_LIB=OFF make -j4 ``` 把上述参数根据实际情况做修改后,运行脚本编译程序: ```shell sh linux_build.sh ``` ### 2.2. 运行和可视化 可执行文件有 **2** 个参数,第一个是前面导出的`inference_model`路径,第二个是需要预测的视频路径。 示例: ```shell ./build/main ./models /PATH/TO/TEST_VIDEO ``` 点击下载[测试视频](https://paddleseg.bj.bcebos.com/deploy/data/test.avi) 预测的结果保存在视频文件`result.avi`中。