Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleX
提交
a452fdf2
P
PaddleX
项目概览
PaddlePaddle
/
PaddleX
通知
138
Star
4
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
43
列表
看板
标记
里程碑
合并请求
5
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleX
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
43
Issue
43
列表
看板
标记
里程碑
合并请求
5
合并请求
5
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
a452fdf2
编写于
6月 29, 2020
作者:
J
Jason
提交者:
GitHub
6月 29, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #177 from joey12300/develop
Use specific path instead of abstract path
上级
9f87b6cb
49b7f4a8
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
61 addition
and
70 deletion
+61
-70
deploy/cpp/scripts/build.sh
deploy/cpp/scripts/build.sh
+5
-5
docs/tutorials/deploy/deploy_server/deploy_cpp/deploy_cpp_linux.md
...rials/deploy/deploy_server/deploy_cpp/deploy_cpp_linux.md
+21
-19
docs/tutorials/deploy/deploy_server/deploy_cpp/deploy_cpp_win_vs2019.md
.../deploy/deploy_server/deploy_cpp/deploy_cpp_win_vs2019.md
+14
-29
docs/tutorials/deploy/deploy_server/encryption.md
docs/tutorials/deploy/deploy_server/encryption.md
+21
-17
未找到文件。
deploy/cpp/scripts/build.sh
浏览文件 @
a452fdf2
...
@@ -4,10 +4,10 @@ WITH_GPU=OFF
...
@@ -4,10 +4,10 @@ WITH_GPU=OFF
WITH_MKL
=
ON
WITH_MKL
=
ON
# 是否集成 TensorRT(仅WITH_GPU=ON 有效)
# 是否集成 TensorRT(仅WITH_GPU=ON 有效)
WITH_TENSORRT
=
OFF
WITH_TENSORRT
=
OFF
# TensorRT 的路径
# TensorRT 的路径
,如果需要集成TensorRT,需修改为您实际安装的TensorRT路径
TENSORRT_DIR
=
/
path/to
/TensorRT/
TENSORRT_DIR
=
/
root/projects
/TensorRT/
# Paddle 预测库路径
# Paddle 预测库路径
, 请修改为您实际安装的预测库路径
PADDLE_DIR
=
/
docker/jiangjiajun/PaddleDetection/deploy/cpp
/fluid_inference
PADDLE_DIR
=
/
root/projects
/fluid_inference
# Paddle 的预测库是否使用静态库来编译
# Paddle 的预测库是否使用静态库来编译
# 使用TensorRT时,Paddle的预测库通常为动态库
# 使用TensorRT时,Paddle的预测库通常为动态库
WITH_STATIC_LIB
=
OFF
WITH_STATIC_LIB
=
OFF
...
@@ -16,7 +16,7 @@ CUDA_LIB=/usr/local/cuda/lib64
...
@@ -16,7 +16,7 @@ CUDA_LIB=/usr/local/cuda/lib64
# CUDNN 的 lib 路径
# CUDNN 的 lib 路径
CUDNN_LIB
=
/usr/local/cuda/lib64
CUDNN_LIB
=
/usr/local/cuda/lib64
# 是否加载加密后的模型
# 是否加载加密后的模型
WITH_ENCRYPTION
=
ON
WITH_ENCRYPTION
=
ON
# 加密工具的路径, 如果使用自带预编译版本可不修改
# 加密工具的路径, 如果使用自带预编译版本可不修改
sh
$(
pwd
)
/scripts/bootstrap.sh
# 下载预编译版本的加密工具
sh
$(
pwd
)
/scripts/bootstrap.sh
# 下载预编译版本的加密工具
...
...
docs/tutorials/deploy/deploy_server/deploy_cpp/deploy_cpp_linux.md
浏览文件 @
a452fdf2
...
@@ -55,17 +55,17 @@ WITH_GPU=OFF
...
@@ -55,17 +55,17 @@ WITH_GPU=OFF
WITH_MKL=ON
WITH_MKL=ON
# 是否集成 TensorRT(仅WITH_GPU=ON 有效)
# 是否集成 TensorRT(仅WITH_GPU=ON 有效)
WITH_TENSORRT=OFF
WITH_TENSORRT=OFF
# TensorRT 的
lib
路径
# TensorRT 的
路径,如果需要集成TensorRT,需修改为您实际安装的TensorRT
路径
TENSORRT_DIR=/
path/to
/TensorRT/
TENSORRT_DIR=/
root/projects
/TensorRT/
# Paddle 预测库路径
# Paddle 预测库路径
, 请修改为您实际安装的预测库路径
PADDLE_DIR=/
path/to/fluid_inference/
PADDLE_DIR=/
root/projects/fluid_inference
# Paddle 的预测库是否使用静态库来编译
# Paddle 的预测库是否使用静态库来编译
# 使用TensorRT时,Paddle的预测库通常为动态库
# 使用TensorRT时,Paddle的预测库通常为动态库
WITH_STATIC_LIB=O
N
WITH_STATIC_LIB=O
FF
# CUDA 的 lib 路径
# CUDA 的 lib 路径
CUDA_LIB=/
path/to/cuda/lib/
CUDA_LIB=/
usr/local/cuda/lib64
# CUDNN 的 lib 路径
# CUDNN 的 lib 路径
CUDNN_LIB=/
path/to/cudnn/lib/
CUDNN_LIB=/
usr/local/cuda/lib64
# 是否加载加密后的模型
# 是否加载加密后的模型
WITH_ENCRYPTION=ON
WITH_ENCRYPTION=ON
...
@@ -74,8 +74,8 @@ sh $(pwd)/scripts/bootstrap.sh # 下载预编译版本的加密工具
...
@@ -74,8 +74,8 @@ sh $(pwd)/scripts/bootstrap.sh # 下载预编译版本的加密工具
ENCRYPTION_DIR=$(pwd)/paddlex-encryption
ENCRYPTION_DIR=$(pwd)/paddlex-encryption
# OPENCV 路径, 如果使用自带预编译版本可不修改
# OPENCV 路径, 如果使用自带预编译版本可不修改
sh $(pwd)/scripts/bootstrap.sh # 下载预编译版本的opencv
OPENCV_DIR=$(pwd)/deps/opencv3gcc4.8/
OPENCV_DIR=$(pwd)/deps/opencv3gcc4.8/
sh $(pwd)/scripts/bootstrap.sh
# 以下无需改动
# 以下无需改动
rm -rf build
rm -rf build
...
@@ -94,7 +94,6 @@ cmake .. \
...
@@ -94,7 +94,6 @@ cmake .. \
-DENCRYPTION_DIR=${ENCRYPTION_DIR} \
-DENCRYPTION_DIR=${ENCRYPTION_DIR} \
-DOPENCV_DIR=${OPENCV_DIR}
-DOPENCV_DIR=${OPENCV_DIR}
make
make
```
```
**注意:**
linux环境下编译会自动下载OPENCV, PaddleX-Encryption和YAML,如果编译环境无法访问外网,可手动下载:
**注意:**
linux环境下编译会自动下载OPENCV, PaddleX-Encryption和YAML,如果编译环境无法访问外网,可手动下载:
...
@@ -119,7 +118,7 @@ yaml-cpp.zip文件下载后无需解压,在cmake/yaml.cmake中将`URL https://
...
@@ -119,7 +118,7 @@ yaml-cpp.zip文件下载后无需解压,在cmake/yaml.cmake中将`URL https://
> **注意:由于PaddleX代码的持续更新,版本低于1.0.0的模型(模型版本可查看model.yml文件中的version字段)暂时无法直接用于预测部署,参考[模型版本升级](../../upgrade_version.md)对模型版本进行升级。**
> **注意:由于PaddleX代码的持续更新,版本低于1.0.0的模型(模型版本可查看model.yml文件中的version字段)暂时无法直接用于预测部署,参考[模型版本升级](../../upgrade_version.md)对模型版本进行升级。**
编译成功后,预测demo的可执行程序分别为
`build/demo/detector`
,
`build/demo/classifer`
,
`build/demo/segmenter`
,用户可根据自己的模型类型选择,其主要命令参数说明如下:
编译成功后,预测demo的可执行程序分别为
`build/demo/detector`
,
`build/demo/classif
i
er`
,
`build/demo/segmenter`
,用户可根据自己的模型类型选择,其主要命令参数说明如下:
| 参数 | 说明 |
| 参数 | 说明 |
| ---- | ---- |
| ---- | ---- |
...
@@ -127,34 +126,37 @@ yaml-cpp.zip文件下载后无需解压,在cmake/yaml.cmake中将`URL https://
...
@@ -127,34 +126,37 @@ yaml-cpp.zip文件下载后无需解压,在cmake/yaml.cmake中将`URL https://
| image | 要预测的图片文件路径 |
| image | 要预测的图片文件路径 |
| image_list | 按行存储图片路径的.txt文件 |
| image_list | 按行存储图片路径的.txt文件 |
| use_gpu | 是否使用 GPU 预测, 支持值为0或1(默认值为0) |
| use_gpu | 是否使用 GPU 预测, 支持值为0或1(默认值为0) |
| use_trt | 是否使用 Tensor
Tr
预测, 支持值为0或1(默认值为0) |
| use_trt | 是否使用 Tensor
RT
预测, 支持值为0或1(默认值为0) |
| gpu_id | GPU 设备ID, 默认值为0 |
| gpu_id | GPU 设备ID, 默认值为0 |
| save_dir | 保存可视化结果的路径, 默认值为"output",
**classfier无该参数**
|
| save_dir | 保存可视化结果的路径, 默认值为"output",
**classfier无该参数**
|
| key | 加密过程中产生的密钥信息,默认值为""表示加载的是未加密的模型 |
| batch_size | 预测的批量大小,默认为1 |
| thread_num | 预测的线程数,默认为cpu处理器个数 |
## 样例
## 样例
可使用
[
小度熊识别模型
](
../deploy_python.html#inference
)
中导出的
`inference_model`
和测试图片进行预测。
可使用
[
小度熊识别模型
](
../deploy_python.html#inference
)
中导出的
`inference_model`
和测试图片进行预测
,导出到/root/projects,模型路径为/root/projects/inference_model
。
`样例一`
:
`样例一`
:
不使用
`GPU`
测试图片
`/
path/to
/xiaoduxiong.jpeg`
不使用
`GPU`
测试图片
`/
root/projects/images
/xiaoduxiong.jpeg`
```
shell
```
shell
./build/demo/detector
--model_dir
=
/
path/to/inference_model
--image
=
/path/to
/xiaoduxiong.jpeg
--save_dir
=
output
./build/demo/detector
--model_dir
=
/
root/projects/inference_model
--image
=
/root/projects/images
/xiaoduxiong.jpeg
--save_dir
=
output
```
```
图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`样例二`
:
`样例二`
:
使用
`GPU`
预测多个图片
`/
path/to
/image_list.txt`
,image_list.txt内容的格式如下:
使用
`GPU`
预测多个图片
`/
root/projects
/image_list.txt`
,image_list.txt内容的格式如下:
```
```
/
path/to
/images/xiaoduxiong1.jpeg
/
root/projects
/images/xiaoduxiong1.jpeg
/
path/to
/images/xiaoduxiong2.jpeg
/
root/projects
/images/xiaoduxiong2.jpeg
...
...
/
path/to
/images/xiaoduxiongn.jpeg
/
root/projects
/images/xiaoduxiongn.jpeg
```
```
```
shell
```
shell
./build/demo/detector
--model_dir
=
/
path/to/models/inference_model
--image_list
=
/root/projects/images_list.txt
--use_gpu
=
1
--save_dir
=
output
./build/demo/detector
--model_dir
=
/
root/projects/inference_model
--image_list
=
/root/projects/images_list.txt
--use_gpu
=
1
--save_dir
=
output
--batch_size
=
2
--thread_num
=
2
```
```
图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
docs/tutorials/deploy/deploy_server/deploy_cpp/deploy_cpp_win_vs2019.md
浏览文件 @
a452fdf2
...
@@ -40,7 +40,7 @@ PaddlePaddle C++ 预测库针对不同的`CPU`,`CUDA`,以及是否支持Tens
...
@@ -40,7 +40,7 @@ PaddlePaddle C++ 预测库针对不同的`CPU`,`CUDA`,以及是否支持Tens
更多和更新的版本,请根据实际情况下载:
[
C++预测库下载列表
](
https://www.paddlepaddle.org.cn/documentation/docs/zh/develop/advanced_guide/inference_deployment/inference/windows_cpp_inference.html
)
更多和更新的版本,请根据实际情况下载:
[
C++预测库下载列表
](
https://www.paddlepaddle.org.cn/documentation/docs/zh/develop/advanced_guide/inference_deployment/inference/windows_cpp_inference.html
)
解压后
`D:\projects\fluid_inference
*
\`目录下主要包含的内容为:
解压后
`D:\projects\fluid_inference\`目录下主要包含的内容为:
```
```
├── \paddle\ # paddle核心库和头文件
├── \paddle\ # paddle核心库和头文件
|
|
...
@@ -61,23 +61,16 @@ PaddlePaddle C++ 预测库针对不同的`CPU`,`CUDA`,以及是否支持Tens
...
@@ -61,23 +61,16 @@ PaddlePaddle C++ 预测库针对不同的`CPU`,`CUDA`,以及是否支持Tens
### Step4: 使用Visual Studio 2019直接编译CMake
### Step4: 使用Visual Studio 2019直接编译CMake
1. 打开Visual Studio 2019 Community,点击`
继续但无需代码
`
1. 打开Visual Studio 2019 Community,点击`
继续但无需代码
`
![step2](../../images/vs2019_step1.png)
![step2](../../images/vs2019_step1.png)
2. 点击: `
文件
`->`
打开
`->`
CMake
`
2. 点击: `
文件
`->`
打开
`->`
CMake
`
![step2.1](../../images/vs2019_step2.png)
![step2.1](../../images/vs2019_step2.png)
选择项目代码所在路径,并打开`
CMakeList.txt
`:
选择项目代码所在路径,并打开`
CMakeList.txt
`:
![step2.2](../../images/vs2019_step3.png)
![step2.2](../../images/vs2019_step3.png)
3. 点击:`
项目
`->`
CMake设置
`
3. 点击:`
项目
`->`
CMake设置
`
![step3](../../images/vs2019_step4.png)
![step3](../../images/vs2019_step4.png)
4. 点击`
浏览
`,分别设置编译选项指定`
CUDA
`、`
OpenCV
`、`
Paddle预测库
`的路径
4. 点击`
浏览
`,分别设置编译选项指定`
CUDA
`、`
OpenCV
`、`
Paddle预测库
`的路径
![step3](../../images/vs2019_step5.png)
![step3](../../images/vs2019_step5.png)
依赖库路径的含义说明如下(带*表示仅在使用**GPU版本**预测库时指定, 其中CUDA库版本尽量对齐,**使用9.0、10.0版本,不使用9.2、10.1等版本CUDA库**):
依赖库路径的含义说明如下(带*表示仅在使用**GPU版本**预测库时指定, 其中CUDA库版本尽量对齐,**使用9.0、10.0版本,不使用9.2、10.1等版本CUDA库**):
...
@@ -90,29 +83,19 @@ PaddlePaddle C++ 预测库针对不同的`CPU`,`CUDA`,以及是否支持Tens
...
@@ -90,29 +83,19 @@ PaddlePaddle C++ 预测库针对不同的`CPU`,`CUDA`,以及是否支持Tens
**注意:**
**注意:**
1. 使用`
CPU
`版预测库,请把`
WITH_GPU
`的`
值
`去掉勾
1. 使用`
CPU
`版预测库,请把`
WITH_GPU
`的`
值
`去掉勾
2. 如果使用的是`
openblas
`版本,请把`
WITH_MKL
`的`
值
`去掉勾
2. 如果使用的是`
openblas
`版本,请把`
WITH_MKL
`的`
值
`去掉勾
3. Windows环境下编译会自动下载YAML,如果编译环境无法访问外网,可手动下载: [yaml-cpp.zip](https://bj.bcebos.com/paddlex/deploy/deps/yaml-cpp.zip)
3. Windows环境下编译会自动下载YAML,如果编译环境无法访问外网,可手动下载: [yaml-cpp.zip](https://bj.bcebos.com/paddlex/deploy/deps/yaml-cpp.zip)
yaml-cpp.zip文件下载后无需解压,在cmake/yaml.cmake中将`
URL https://bj.bcebos.com/paddlex/deploy/deps/yaml-cpp.zip
` 中的网址,改为下载文件的路径。
yaml-cpp.zip文件下载后无需解压,在cmake/yaml.cmake中将`
URL https://bj.bcebos.com/paddlex/deploy/deps/yaml-cpp.zip
` 中的网址,改为下载文件的路径。
4. 如果需要使用模型加密功能,需要手动下载[Windows预测模型加密工具](https://bj.bcebos.com/paddlex/tools/win/paddlex-encryption.zip),解压到D:/projects。解压后目录为D:/projects/paddlex-encryption。编译时需勾选WITH_EBNCRYPTION并且在ENCRTYPTION_DIR填入D:/projects/paddlex-encryption。
4. 如果需要使用模型加密功能,需要手动下载[Windows预测模型加密工具](https://bj.bcebos.com/paddlex/tools/win/paddlex-encryption.zip),解压到某目录\\path\\to\\paddlex-encryption。编译时需勾选WITH_EBNCRYPTION并且在ENCRTYPTION_DIR填入\\path\\to\\paddlex-encryption。
![step_encryption](../../images/vs2019_step_encryption.png)
![step_encryption](../../images/vs2019_step_encryption.png)
![step4](../../images/vs2019_step6.png)
![step4](../../images/vs2019_step6.png)
**设置完成后**, 点击上图中`
保存并生成CMake缓存以加载变量
`。
**设置完成后**, 点击上图中`
保存并生成CMake缓存以加载变量
`。
5. 点击`
生成
`->`
全部生成
`
5. 点击`
生成
`->`
全部生成
`
![step6](../../images/vs2019_step7.png)
![step6](../../images/vs2019_step7.png)
### Step5: 预测及可视化
### Step5: 预测及可视化
**在加载模型前,请检查你的模型目录中文件应该包括`
model.yml
`、`
__model__
`和`
__params__
`三个文件。如若不满足这个条件,请参考[模型导出为Inference文档](../deploy_python.html#inference)将模型导出为部署格式。**
**在加载模型前,请检查你的模型目录中文件应该包括`
model.yml
`、`
__model__
`和`
__params__
`三个文件。如若不满足这个条件,请参考[模型导出为Inference文档](../deploy_python.html#inference)将模型导出为部署格式。**
**注意:由于PaddleX代码的持续更新,版本低于1.0.0的模型(模型版本可查看model.yml文件中的version字段)暂时无法直接用于预测部署,参考[模型版本升级](../../upgrade_version.md)对模型版本进行升级。**
**注意:由于PaddleX代码的持续更新,版本低于1.0.0的模型(模型版本可查看model.yml文件中的version字段)暂时无法直接用于预测部署,参考[模型版本升级](../../upgrade_version.md)对模型版本进行升级。**
...
@@ -124,7 +107,7 @@ d:
...
@@ -124,7 +107,7 @@ d:
cd D:\projects\PaddleX\deploy\cpp\out\build\x64-Release
cd D:\projects\PaddleX\deploy\cpp\out\build\x64-Release
```
```
编译成功后,预测demo的入口程序为`
paddlex_inference
\d
etector.exe
`,`
paddlex_inference
\c
lassifer.exe
`,`
paddlex_inference
\s
egmenter.exe
`,用户可根据自己的模型类型选择,其主要命令参数说明如下:
编译成功后,预测demo的入口程序为`
paddlex_inference
\d
etector.exe
`,`
paddlex_inference
\c
lassif
i
er.exe
`,`
paddlex_inference
\s
egmenter.exe
`,用户可根据自己的模型类型选择,其主要命令参数说明如下:
| 参数 | 说明 |
| 参数 | 说明 |
| ---- | ---- |
| ---- | ---- |
...
@@ -134,18 +117,20 @@ cd D:\projects\PaddleX\deploy\cpp\out\build\x64-Release
...
@@ -134,18 +117,20 @@ cd D:\projects\PaddleX\deploy\cpp\out\build\x64-Release
| use_gpu | 是否使用 GPU 预测, 支持值为0或1(默认值为0) |
| use_gpu | 是否使用 GPU 预测, 支持值为0或1(默认值为0) |
| gpu_id | GPU 设备ID, 默认值为0 |
| gpu_id | GPU 设备ID, 默认值为0 |
| save_dir | 保存可视化结果的路径, 默认值为"output",classfier无该参数 |
| save_dir | 保存可视化结果的路径, 默认值为"output",classfier无该参数 |
| key | 加密过程中产生的密钥信息,默认值为""表示加载的是未加密的模型 |
| batch_size | 预测的批量大小,默认为1 |
| thread_num | 预测的线程数,默认为cpu处理器个数 |
## 样例
## 样例
可使用[小度熊识别模型](../deploy_python.md)中导出的`
inference_model
`和测试图片进行预测。
可使用[小度熊识别模型](../deploy_python.md)中导出的`
inference_model
`和测试图片进行预测
, 导出到D:/projects,模型路径为D:/projects/inference_model
。
`
样例一
`:
`
样例一
`:
不使用`
GPU
`测试图片 `
\\
path
\\
to
\\
xiaoduxiong.jpeg
`
不使用`
GPU
`测试图片 `
D:
\\
images
\\
xiaoduxiong.jpeg
`
```shell
```shell
.\\paddlex_inference\\detector.exe --model_dir=
\\path\\to
\\inference_model --image=D:\\images\\xiaoduxiong.jpeg --save_dir=output
.\\paddlex_inference\\detector.exe --model_dir=
D:\\projects
\\inference_model --image=D:\\images\\xiaoduxiong.jpeg --save_dir=output
```
```
图片文件`
可视化预测结果
`会保存在`
save_dir
`参数设置的目录下。
图片文件`
可视化预测结果
`会保存在`
save_dir
`参数设置的目录下。
...
@@ -153,14 +138,14 @@ cd D:\projects\PaddleX\deploy\cpp\out\build\x64-Release
...
@@ -153,14 +138,14 @@ cd D:\projects\PaddleX\deploy\cpp\out\build\x64-Release
`
样例二
`:
`
样例二
`:
使用`
GPU
`预测多个图片`
\\
path
\\
to
\\
image_list.txt
`,image_list.txt内容的格式如下:
使用`
GPU
`预测多个图片`
D:
\\
images
\\
image_list.txt
`,image_list.txt内容的格式如下:
```
```
\\path\\to
\\images\\xiaoduxiong1.jpeg
D:
\\images\\xiaoduxiong1.jpeg
\\path\\to
\\images\\xiaoduxiong2.jpeg
D:
\\images\\xiaoduxiong2.jpeg
...
...
\\path\\to
\\images\\xiaoduxiongn.jpeg
D:
\\images\\xiaoduxiongn.jpeg
```
```
```shell
```shell
.\\paddlex_inference\\detector.exe --model_dir=
\\path\\to\\inference_model --image_list=\\path\\to\\images_list.txt --use_gpu=1 --save_dir=output
.\\paddlex_inference\\detector.exe --model_dir=
D:\\projects\\inference_model --image_list=D:\\images\\image_list.txt --use_gpu=1 --save_dir=output --batch_size=2 --thread_num=2
```
```
图片文件`
可视化预测结果
`会保存在`
save_dir
`
参数设置的目录下。
图片文件`
可视化预测结果
`会保存在`
save_dir
`
参数设置的目录下。
docs/tutorials/deploy/deploy_server/encryption.md
浏览文件 @
a452fdf2
...
@@ -70,12 +70,14 @@ paddlex-encryption
...
@@ -70,12 +70,14 @@ paddlex-encryption
Linux:
Linux:
```
```
./paddlex-encryption/tool/paddlex_encrypt_tool -model_dir /path/to/paddlex_inference_model -save_dir /path/to/paddlex_encrypted_model
# 假设模型在/root/projects下
./paddlex-encryption/tool/paddlex_encrypt_tool -model_dir /root/projects/paddlex_inference_model -save_dir /root/projects/paddlex_encrypted_model
```
```
Windows:
Windows:
```
```
./paddlex-encryption/tool/paddlex_encrypt_tool.exe -model_dir path\to\paddlex_inference_model -save_dir path/to/paddlex_encrypted_model
# 假设模型在D:/projects下
.\paddlex-encryption\tool\paddlex_encrypt_tool.exe -model_dir D:\\projects\\paddlex_inference_model -save_dir D:\\projects\\paddlex_encrypted_model
```
```
`-model_dir`
用于指定inference模型路径(参考
[
导出inference模型
](
deploy_python.html#inference
)
将模型导出为inference格式模型),可使用
[
导出小度熊识别模型
](
deploy_python.html#inference
)
中导出的
`inference_model`
。加密完成后,加密过的模型会保存至指定的
`-save_dir`
下,包含
`__model__.encrypted`
、
`__params__.encrypted`
和
`model.yml`
三个文件,同时生成密钥信息,命令输出如下图所示,密钥为
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
`-model_dir`
用于指定inference模型路径(参考
[
导出inference模型
](
deploy_python.html#inference
)
将模型导出为inference格式模型),可使用
[
导出小度熊识别模型
](
deploy_python.html#inference
)
中导出的
`inference_model`
。加密完成后,加密过的模型会保存至指定的
`-save_dir`
下,包含
`__model__.encrypted`
、
`__params__.encrypted`
和
`model.yml`
三个文件,同时生成密钥信息,命令输出如下图所示,密钥为
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
...
@@ -97,6 +99,8 @@ Windows:
...
@@ -97,6 +99,8 @@ Windows:
| gpu_id | GPU 设备ID, 默认值为0 |
| gpu_id | GPU 设备ID, 默认值为0 |
| save_dir | 保存可视化结果的路径, 默认值为"output",classifier无该参数 |
| save_dir | 保存可视化结果的路径, 默认值为"output",classifier无该参数 |
| key | 加密过程中产生的密钥信息,默认值为""表示加载的是未加密的模型 |
| key | 加密过程中产生的密钥信息,默认值为""表示加载的是未加密的模型 |
| batch_size | 预测的批量大小,默认为1 |
| thread_num | 预测的线程数,默认为cpu处理器个数 |
## 样例
## 样例
...
@@ -105,30 +109,30 @@ Windows:
...
@@ -105,30 +109,30 @@ Windows:
`样例一`
:
`样例一`
:
不使用
`GPU`
测试图片
`/
path/to
/xiaoduxiong.jpeg`
不使用
`GPU`
测试图片
`/
root/projects/images
/xiaoduxiong.jpeg`
```
shell
```
shell
./build/demo/detector
--model_dir
=
/
path/to/inference_model
--image
=
/path/to
/xiaoduxiong.jpeg
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
./build/demo/detector
--model_dir
=
/
root/projects/inference_model
--image
=
/root/projects
/xiaoduxiong.jpeg
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
```
```
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`样例二`
:
`样例二`
:
使用
`GPU`
预测多个图片
`/
path/to
/image_list.txt`
,image_list.txt内容的格式如下:
使用
`GPU`
预测多个图片
`/
root/projects
/image_list.txt`
,image_list.txt内容的格式如下:
```
```
/
path/to
/images/xiaoduxiong1.jpeg
/
root/projects
/images/xiaoduxiong1.jpeg
/
path/to/image
s/xiaoduxiong2.jpeg
/
root/project
s/xiaoduxiong2.jpeg
...
...
/
path/to/image
s/xiaoduxiongn.jpeg
/
root/project
s/xiaoduxiongn.jpeg
```
```
```
shell
```
shell
./build/demo/detector
--model_dir
=
/
path/to
/models/inference_model
--image_list
=
/root/projects/images_list.txt
--use_gpu
=
1
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
./build/demo/detector
--model_dir
=
/
root/projects
/models/inference_model
--image_list
=
/root/projects/images_list.txt
--use_gpu
=
1
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
```
```
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
### 2.2 Windows平台使用
### 2.2 Windows平台使用
参考
[
Windows平台编译指南
](
deploy_cpp/deploy_cpp_win_vs2019.md
)
。
参数与Linux版本预测部署一致。预测demo的入口程序为paddlex_inference
\d
etector.exe,paddlex_inference
\c
lassif
er.exe,paddlex_inference
\s
egmenter.exe。
参考
[
Windows平台编译指南
](
deploy_cpp/deploy_cpp_win_vs2019.md
)
。
需自行下载Windows版PaddleX加密工具压缩包,解压,在编译指南的编译流程基础上,在CMake设置中勾选WITH_ENCRYPTION,ENCRYPTION_DIR填写为加密工具包解压后的目录,再进行编译。参数与Linux版本预测部署一致。预测demo的入口程序为paddlex_inference
\d
etector.exe,paddlex_inference
\c
lassifi
er.exe,paddlex_inference
\s
egmenter.exe。
## 样例
## 样例
...
@@ -136,24 +140,24 @@ Windows:
...
@@ -136,24 +140,24 @@ Windows:
`样例一`
:
`样例一`
:
不使用
`GPU`
测试图片
`
\path\to
\xiaoduxiong.jpeg`
不使用
`GPU`
测试图片
`
D:\\images\
\xiaoduxiong.jpeg`
```
shell
```
shell
.
\
p
addlex_inference
\d
etector.exe
--model_dir
=
\p
ath
\t
o
\i
nference_model
--image
=
\p
ath
\t
o
\x
iaoduxiong.jpeg
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
.
\
\
paddlex_inference
\\
detector.exe
--model_dir
=
D:
\\
projects
\\
inference_model
--image
=
D:
\\
images
\
\
xiaoduxiong.jpeg
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
```
```
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`样例二`
:
`样例二`
:
使用
`GPU`
预测多个图片
`
\path\to
\image_list.txt`
,image_list.txt内容的格式如下:
使用
`GPU`
预测多个图片
`
D:\\projects\
\image_list.txt`
,image_list.txt内容的格式如下:
```
```
\\path\\to
\\images\\xiaoduxiong1.jpeg
D:\\projects
\\images\\xiaoduxiong1.jpeg
\\path\\to
\\images\\xiaoduxiong2.jpeg
D:\\projects
\\images\\xiaoduxiong2.jpeg
...
...
\\path\\to
\\images\\xiaoduxiongn.jpeg
D:\\projects
\\images\\xiaoduxiongn.jpeg
```
```
```
shell
```
shell
.
\
p
addlex_inference
\d
etector.exe
--model_dir
=
\p
ath
\t
o
\m
odels
\i
nference_model
--image_list
=
\p
ath
\t
o
\i
mages_list.txt
--use_gpu
=
1
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
.
\
\
paddlex_inference
\\
detector.exe
--model_dir
=
D:
\\
projects
\\
inference_encrypted_model
--image_list
=
D:
\\
projects
\
\
images_list.txt
--use_gpu
=
1
--save_dir
=
output
--key
=
kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c
=
```
```
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
`--key`
传入加密工具输出的密钥,例如
`kLAl1qOs5uRbFt0/RrIDTZW2+tOf5bzvUIaHGF8lJ1c=`
, 图片文件
`可视化预测结果`
会保存在
`save_dir`
参数设置的目录下。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录