python_deploy.md 4.0 KB
Newer Older
1 2 3 4
# Python 预测推理

---

W
weishengyu 已提交
5
首先请参考文档[环境准备](../installation/install_paddleclas.md)配置运行环境。
6

C
cuicheng01 已提交
7 8
## 目录

D
dongshuilong 已提交
9 10 11 12 13
- [1. 图像分类模型推理](#1)
- [2. PP-ShiTu模型推理](#2)
	- [2.1 主体检测模型推理](#2.1)
	- [2.2 特征提取模型推理](#2.2)
	- [2.3 PP-ShiTu PipeLine推理](#2.3)
C
cuicheng01 已提交
14

S
sibo2rr 已提交
15
<a name="1"></a>
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
## 1. 图像分类推理

首先请参考文档[模型导出](./export_model.md)准备 inference 模型,然后进入 PaddleClas 的 `deploy` 目录下:

```shell
cd /path/to/PaddleClas/deploy
```

使用以下命令进行预测:

```shell
python python/predict_cls.py -c configs/inference_cls.yaml
```

在配置文件 `configs/inference_cls.yaml` 中有以下字段用于配置预测参数:
* `Global.infer_imgs`:待预测的图片文件路径;
* `Global.inference_model_dir`:inference 模型文件所在目录,该目录下需要有文件 `inference.pdmodel``inference.pdiparams` 两个文件;
* `Global.use_tensorrt`:是否使用 TesorRT 预测引擎,默认为 `False`
* `Global.use_gpu`:是否使用 GPU 预测,默认为 `True`
* `Global.enable_mkldnn`:是否启用 `MKL-DNN` 加速库,默认为 `False`。注意 `enable_mkldnn``use_gpu` 同时为 `True` 时,将忽略 `enable_mkldnn`,而使用 GPU 预测;
36
* `Global.use_fp16`:是否启用 `FP16`,默认为 `False`
37 38 39 40 41 42
* `PreProcess`:用于数据预处理配置;
* `PostProcess`:由于后处理配置;
* `PostProcess.Topk.class_id_map_file`:数据集 label 的映射文件,默认为 `./utils/imagenet1k_label_list.txt`,该文件为 PaddleClas 所使用的 ImageNet 数据集 label 映射文件。

**注意**:
* 如果使用 VisionTransformer 系列模型,如 `DeiT_***_384`, `ViT_***_384` 等,请注意模型的输入数据尺寸,部分模型需要修改参数: `PreProcess.resize_short=384`, `PreProcess.resize=384`
S
sibo2rr 已提交
43
* 如果你希望提升评测模型速度,使用 GPU 评测时,建议开启 TensorRT 加速预测,使用 CPU 评测时,建议开启 MKL-DNN 加速预测。
44

S
sibo2rr 已提交
45
<a name="2"></a>
D
dongshuilong 已提交
46 47 48 49 50 51
## 2. PP-ShiTu模型推理

PP-ShiTu整个Pipeline包含三部分:主体检测、特提取模型、特征检索。其中主体检测、特征模型可以单独推理使用。单独主体检测详见[2.1](#2.1),特征提取模型单独推理详见[2.2](#2.2), PP-ShiTu整体推理详见[2.3](#2.3)

<a name="2.1"></a>
### 2.1 主体检测模型推理
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77

进入 PaddleClas 的 `deploy` 目录下:

```shell
cd /path/to/PaddleClas/deploy
```

准备 PaddleClas 提供的主体检测 inference 模型:

```shell
mkdir -p models
# 下载通用检测 inference 模型并解压
wget -P ./models/ https://paddle-imagenet-models-name.bj.bcebos.com/dygraph/rec/models/inference/ppyolov2_r50vd_dcn_mainbody_v1.0_infer.tar
tar -xf ./models/ppyolov2_r50vd_dcn_mainbody_v1.0_infer.tar -C ./models/
```

使用以下命令进行预测:

```shell
python python/predict_det.py -c configs/inference_det.yaml
```

在配置文件 `configs/inference_det.yaml` 中有以下字段用于配置预测参数:
* `Global.infer_imgs`:待预测的图片文件路径;
* `Global.use_gpu`: 是否使用 GPU 预测,默认为 `True`

C
cuicheng01 已提交
78

D
dongshuilong 已提交
79 80
<a name="2.2"></a>
### 2.2 特征提取模型推理
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98

下面以商品特征提取为例,介绍特征提取模型推理。首先进入 PaddleClas 的 `deploy` 目录下:

```shell
cd /path/to/PaddleClas/deploy
```

准备 PaddleClas 提供的商品特征提取 inference 模型:

```shell
mkdir -p models
# 下载商品特征提取 inference 模型并解压
wget -P ./models/ https://paddle-imagenet-models-name.bj.bcebos.com/dygraph/rec/models/inference/product_ResNet50_vd_aliproduct_v1.0_infer.tar
tar -xf ./models/product_ResNet50_vd_aliproduct_v1.0_infer.tar -C ./models/
```

上述预测命令可以得到一个 512 维的特征向量,直接输出在在命令行中。

D
dongshuilong 已提交
99 100
<a name="2.3"></a>
### 2.3. PP-ShiTu PipeLine推理
101 102

主体检测、特征提取和向量检索的串联预测,可以参考图像识别[快速体验](../quick_start/quick_start_recognition.md)