# 图像分类模型卷积层通道剪裁示例 本示例将演示如何按指定的剪裁率对每个卷积层的通道数进行剪裁。该示例默认会自动下载并使用mnist数据。 当前示例支持以下分类模型: - MobileNetV1 - MobileNetV2 - ResNet50 - PVANet ## 1. 数据准备 本示例支持`MNIST`和`ImageNet`两种数据。默认情况下,会自动下载并使用`MNIST`数据,如果需要使用`ImageNet`数据,请按以下步骤操作: 1). 根据分类模型中[ImageNet数据准备文档](https://github.com/PaddlePaddle/models/tree/develop/PaddleCV/image_classification#%E6%95%B0%E6%8D%AE%E5%87%86%E5%A4%87)下载数据到`PaddleSlim/demo/data/ILSVRC2012`路径下。 2). 使用`train.py`脚本时,指定`--data`选项为`imagenet`. ## 2. 下载预训练模型 如果使用`ImageNet`数据,建议在预训练模型的基础上进行剪裁,请从[分类库](https://github.com/PaddlePaddle/models/tree/develop/PaddleCV/image_classification#%E5%B7%B2%E5%8F%91%E5%B8%83%E6%A8%A1%E5%9E%8B%E5%8F%8A%E5%85%B6%E6%80%A7%E8%83%BD)中下载合适的预训练模型。 这里以`MobileNetV1`为例,下载并解压预训练模型到当前路径: ``` wget http://paddle-imagenet-models-name.bj.bcebos.com/MobileNetV1_pretrained.tar tar -xf MobileNetV1_pretrained.tar ``` 使用`train.py`脚本时,指定`--pretrained_model`加载预训练模型。 ## 3. 启动剪裁任务 通过以下命令启动裁剪任务: ``` export CUDA_VISIBLE_DEVICES=0 python train.py \ --model "MobileNet" \ --pruned_ratio 0.31 \ --data "mnist" \ --criterion "l1_norm" ``` 其中,`model`用于指定待裁剪的模型。`pruned_ratio`用于指定各个卷积层通道数被裁剪的比例。`data`选项用于指定使用的数据集。 `criterion` 选项用于指定所使用的剪裁算法策略,现在支持`l1_norm`, `bn_scale`, `geometry_median`。默认为`l1_norm`。可以 设置该参数以改变剪裁算法策略。该目录下的四个shell脚本文件是在ResNet34, MobileNetV1, MobileNetV2等三个模型上进行的四组 `criterion`设置为`geometry_median`的实验,可以直接运行脚本文件启动剪裁实验。 执行`python train.py --help`查看更多选项。 在本示例中,会在日志中输出剪裁前后的`FLOPs`,并且每训练一轮就会保存一个模型到文件系统。 ## 4. 加载和评估模型 本节介绍如何加载训练过程中保存的模型。 执行以下代码加载模型并评估模型在测试集上的指标。 ``` python eval.py \ --model "MobileNet" \ --data "mnist" \ --model_path "./models/0" ``` 在脚本`eval.py`中,使用`paddleslim.prune.load_model`接口加载剪裁得到的模型。 ## 5. 接口介绍 该示例使用了`paddleslim.Pruner`工具类,用户接口使用介绍请参考:[API文档](https://paddlepaddle.github.io/PaddleSlim/api/prune_api/) 在调用`paddleslim.Pruner`工具类时,需要指定待裁卷积层的参数名称。不同模型的参数命名不同, 在`train.py`脚本中,提供了`get_pruned_params`方法,根据用户设置的选项`--model`确定要裁剪的参数。