linux_build.md 4.5 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版本的预测库时需要)
J
joey12300 已提交
10
* CentOS 7.6, Ubuntu 16.04, Ubuntu 18.04 (均在以上系统验证过)
B
Bin Long 已提交
11 12 13 14 15 16

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

### Step1: 下载代码

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

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


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

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

26 27
|  版本   | 链接  |
|  ----  | ----  |
J
joey12300 已提交
28 29 30
| 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) |
31

32

J
joey12300 已提交
33
针对不同的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 已提交
34 35 36 37 38 39 40 41 42 43 44 45 46


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

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

B
Bin Long 已提交
48 49 50 51 52 53 54 55 56
```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
57
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 已提交
58 59 60 61
make -j4
make install
```

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

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

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

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

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

B
Bin Long 已提交
77 78 79
```shell
cd /root/projects/PaddleSeg/inference
mkdir build && cd build
80
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 已提交
81 82 83
make
```

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

88 89 90 91
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 已提交
92

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

执行命令:

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

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