quick_start_multilabel_classification.md 2.8 KB
Newer Older
1 2
# 多标签分类quick start

3
基于 [NUS-WIDE-SCENE](https://lms.comp.nus.edu.sg/wp-content/uploads/2019/research/nuswide/NUS-WIDE.html) 数据集,体验多标签分类的训练、评估、预测的过程,该数据集是 NUS-WIDE 数据集的一个子集。请首先安装 PaddlePaddle 和 PaddleClas,具体安装步骤可详看 [Paddle 安装文档](../installation/install_paddle.md)[PaddleClas 安装文档](../installation/install_paddleclas.md)
4 5 6 7


## 目录

8 9 10 11 12
* [1. 数据和模型准备](#1)
* [2. 模型训练](#2)
* [3. 模型评估](#3)
* [4. 模型预测](#4)
* [5. 基于预测引擎预测](#5)
13 14 15 16
  * [5.1 导出inference model](#5.1)
  * [5.2 基于预测引擎预测](#5.2)

<a name="1"></a>
17
## 1. 数据和模型准备
18

19
* 进入 `PaddleClas` 目录。
20 21 22 23 24

```
cd path_to_PaddleClas
```

25
* 创建并进入 `dataset/NUS-WIDE-SCENE` 目录,下载并解压 NUS-WIDE-SCENE 数据集。
26 27 28 29 30 31 32 33

```shell
mkdir dataset/NUS-WIDE-SCENE
cd dataset/NUS-WIDE-SCENE
wget https://paddle-imagenet-models-name.bj.bcebos.com/data/NUS-SCENE-dataset.tar
tar -xf NUS-SCENE-dataset.tar
```

34
* 返回 `PaddleClas` 根目录
35 36 37 38 39 40

```
cd ../../
```

<a name="2"></a>
41
## 2. 模型训练
42 43 44 45 46 47 48 49 50

```shell
export CUDA_VISIBLE_DEVICES=0,1,2,3
python3 -m paddle.distributed.launch \
    --gpus="0,1,2,3" \
    tools/train.py \
        -c ./ppcls/configs/quick_start/professional/MobileNetV1_multilabel.yaml
```

51
训练 10 epoch 之后,验证集最好的正确率应该在 0.95 左右。
52 53

<a name="3"></a>
54 55

## 3. 模型评估
56 57 58 59 60 61 62 63

```bash
python3 tools/eval.py \
    -c ./ppcls/configs/quick_start/professional/MobileNetV1_multilabel.yaml \
    -o Arch.pretrained="./output/MobileNetV1/best_model"
```

<a name="4"></a>
64
## 4. 模型预测
65 66 67 68 69 70 71 72 73 74 75 76 77

```bash
python3 tools/infer.py \
    -c ./ppcls/configs/quick_start/professional/MobileNetV1_multilabel.yaml \
    -o Arch.pretrained="./output/MobileNetV1/best_model"
```

得到类似下面的输出:
```  
[{'class_ids': [6, 13, 17, 23, 26, 30], 'scores': [0.95683, 0.5567, 0.55211, 0.99088, 0.5943, 0.78767], 'file_name': './deploy/images/0517_2715693311.jpg', 'label_names': []}]
```

<a name="5"></a>
78
## 5. 基于预测引擎预测
79 80 81 82 83 84 85 86 87

<a name="5.1"></a>
### 5.1 导出inference model

```bash
python3 tools/export_model.py \
    -c ./ppcls/configs/quick_start/professional/MobileNetV1_multilabel.yaml \
    -o Arch.pretrained="./output/MobileNetV1/best_model"
```
88
inference model 的路径默认在当前路径下 `./inference`
89 90 91 92

<a name="5.2"></a>
### 5.2 基于预测引擎预测

93
首先进入 deploy 目录下:
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109

```bash
cd ./deploy
```

通过预测引擎推理预测:

```
python3 python/predict_cls.py \
     -c configs/inference_multilabel_cls.yaml
```

得到类似下面的输出:
```
0517_2715693311.jpg:    class id(s): [6, 13, 17, 23, 26, 30], score(s): [0.96, 0.56, 0.55, 0.99, 0.59, 0.79], label_name(s): []
```