linux_build.md 4.4 KB
Newer Older
B
Bin Long 已提交
1 2 3
# Linux平台 编译指南

## 说明
4
本文档在 `Linux`平台使用`GCC 4.8.5``GCC 4.9.4`测试过,如果需要使用更高版本的GCC编译使用,则需要重新编译PaddlePaddle预测库,请参考: [从源码编译Paddle预测库](https://www.paddlepaddle.org.cn/documentation/docs/zh/develop/advanced_usage/deploy/inference/build_and_install_lib_cn.html#id15)
B
Bin Long 已提交
5 6 7 8

## 前置条件
* G++ 4.8.2 ~ 4.9.4
* CMake 3.0+
J
joey12300 已提交
9
* CUDA 9.0 / CUDA 10.0, cudnn 7+ (仅在使用GPU版本的预测库时需要)
B
Bin Long 已提交
10 11 12 13 14 15

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

### Step1: 下载代码

1. `mkdir -p /root/projects/ && cd /root/projects`
B
Bin Long 已提交
16
2. `git clone https://github.com/PaddlePaddle/PaddleSeg.git`
B
Bin Long 已提交
17

B
Bin Long 已提交
18
`C++`预测代码在`/root/projects/PaddleSeg/inference` 目录,该目录不依赖任何`PaddleSeg`下其他目录。
B
Bin Long 已提交
19 20 21 22


### Step2: 下载PaddlePaddle C++ 预测库 fluid_inference

J
joey12300 已提交
23
PaddlePaddle C++ 预测库主要分为CPU版本和GPU版本。其中,针对不同的CUDA版本,GPU版本预测库又分为两个版本预测库:CUDA 9.0和CUDA 10.0版本预测库。以下为各版本C++预测库的下载链接:
J
joey12300 已提交
24

25 26
|  版本   | 链接  |
|  ----  | ----  |
J
joey12300 已提交
27 28 29
| CPU版本  | [fluid_inference.tgz](https://bj.bcebos.com/paddlehub/paddle_inference_lib/fluid_inference_linux_cpu_1.6.1.tgz) |
| CUDA 9.0版本  | [fluid_inference.tgz](https://bj.bcebos.com/paddlehub/paddle_inference_lib/fluid_inference_linux_cuda97_1.6.1.tgz) |
| CUDA 10.0版本  | [fluid_inference.tgz](https://bj.bcebos.com/paddlehub/paddle_inference_lib/fluid_inference_linux_cuda10_1.6.1.tgz) |
30

31

J
joey12300 已提交
32
针对不同的CPU类型、不同的指令集,官方提供更多可用的预测库版本,目前已经推出1.6版本的预测库。其余版本具体请参考以下链接:[C++预测库下载列表](https://www.paddlepaddle.org.cn/documentation/docs/zh/develop/advanced_usage/deploy/inference/build_and_install_lib_cn.html)
B
Bin Long 已提交
33 34 35 36 37 38 39 40 41 42 43 44 45


下载并解压后`/root/projects/fluid_inference`目录包含内容为:
```
fluid_inference
├── paddle # paddle核心库和头文件
|
├── third_party # 第三方依赖库和头文件
|
└── version.txt # 版本和编译信息
```

### Step3: 安装配置OpenCV
B
Bin Long 已提交
46

B
Bin Long 已提交
47 48 49 50 51 52 53 54 55
```shell
# 0. 切换到/root/projects目录
cd /root/projects
# 1. 下载OpenCV3.4.6版本源代码
wget -c https://paddleseg.bj.bcebos.com/inference/opencv-3.4.6.zip
# 2. 解压
unzip opencv-3.4.6.zip && cd opencv-3.4.6
# 3. 创建build目录并编译, 这里安装到/usr/local/opencv3目录
mkdir build && cd build
56
cmake .. -DCMAKE_INSTALL_PREFIX=/root/projects/opencv3 -DCMAKE_BUILD_TYPE=Release -DBUILD_SHARED_LIBS=OFF -DWITH_IPP=OFF -DBUILD_IPP_IW=OFF -DWITH_LAPACK=OFF -DWITH_EIGEN=OFF -DCMAKE_INSTALL_LIBDIR=lib64 -DWITH_ZLIB=ON -DBUILD_ZLIB=ON -DWITH_JPEG=ON -DBUILD_JPEG=ON -DWITH_PNG=ON -DBUILD_PNG=ON -DWITH_TIFF=ON -DBUILD_TIFF=ON
B
Bin Long 已提交
57 58 59 60
make -j4
make install
```

B
Bin Long 已提交
61 62
**注意:** 上述操作完成后,`opencv` 被安装在 `/root/projects/opencv3` 目录。

B
Bin Long 已提交
63
### Step4: 编译
B
Bin Long 已提交
64

J
joey12300 已提交
65
`CMake`编译时,涉及到四个编译参数用于指定核心依赖库的路径, 他们的定义如下:(带*表示仅在使用**GPU版本**预测库时指定,其中CUDA库版本尽量对齐,**使用9.0、10.0版本,不使用9.2、10.1版本CUDA库**
B
Bin Long 已提交
66 67 68

|  参数名   | 含义  |
|  ----  | ----  |
69 70
| * CUDA_LIB  | CUDA的库路径 |
| * CUDNN_LIB | cudnn的库路径|
71
| OPENCV_DIR  | OpenCV的安装路径 |
B
Bin Long 已提交
72 73
| PADDLE_DIR | Paddle预测库的路径 |

74
在使用**GPU版本**预测库进行编译时,可执行下列操作。**注意**把对应的参数改为你的上述依赖库实际路径:
B
Bin Long 已提交
75

B
Bin Long 已提交
76 77 78
```shell
cd /root/projects/PaddleSeg/inference
mkdir build && cd build
79
cmake .. -DWITH_GPU=ON  -DPADDLE_DIR=/root/projects/fluid_inference -DCUDA_LIB=/usr/local/cuda/lib64/ -DOPENCV_DIR=/root/projects/opencv3/ -DCUDNN_LIB=/usr/local/cuda/lib64/ -DWITH_STATIC_LIB=OFF
B
Bin Long 已提交
80 81 82
make
```

83 84 85
在使用**CPU版本**预测库进行编译时,可执行下列操作。
```shell
cd /root/projects/PaddleSeg/inference
J
joey12300 已提交
86

87 88 89 90
mkdir build && cd build
cmake .. -DWITH_GPU=OFF  -DPADDLE_DIR=/root/projects/fluid_inference -DOPENCV_DIR=/root/projects/opencv3/ -DWITH_STATIC_LIB=OFF
make
```
B
Bin Long 已提交
91

B
Bin Long 已提交
92 93 94 95 96 97 98 99
### Step5: 预测及可视化

执行命令:

```
./demo --conf=/path/to/your/conf --input_dir=/path/to/your/input/data/directory
```

J
joey12300 已提交
100
更详细说明请参考README文档: [预测和可视化部分](../README.md)