README.md 3.25 KB
Newer Older
sugon_cxj's avatar
sugon_cxj committed
1
# mobilenet_prune
chenxj's avatar
chenxj committed
2
3
4
5
6
7
8
## 论文
EfficientNet
https://arxiv.org/pdf/1905.11946.pdf
mobilenetv2
https://arxiv.org/pdf/1801.04381.pdf
mobilenetv3
https://arxiv.org/pdf/1905.02244.pdf
sugon_cxj's avatar
sugon_cxj committed
9
## 模型结构
chenxj's avatar
chenxj committed
10
11
12
mobilenetv2:

![image](https://developer.hpccube.com/codes/modelzoo/mobilenet_prune/-/raw/main/mobilenet.png)
sugon_cxj's avatar
sugon_cxj committed
13
14
15
16
17
18
19
模型结构见官方论文:
EfficientNet
https://arxiv.org/pdf/1905.11946.pdf
mobilenetv2
https://arxiv.org/pdf/1801.04381.pdf
mobilenetv3
https://arxiv.org/pdf/1905.02244.pdf
chenxj's avatar
chenxj committed
20
21
## 算法原理
CNN原理
sugon_cxj's avatar
sugon_cxj committed
22
23
## 数据集
torchvision.datasets.CIFAR10
chenxj's avatar
chenxj committed
24
## 环境配置
chenxj's avatar
chenxj committed
25
[光源](https://sourcefind.cn/#/main-page)可拉取剪枝及微调的docker镜像,在[光合开发者社区](https://cancon.hpccube.com:65024/4/main/)可下载torch安装包。mobilenet_prune推荐的镜像如下:
sugon_cxj's avatar
sugon_cxj committed
26
27
28
29
30
31
32
33
34
35
36
37
38
```
docker pull image.sourcefind.cn:5000/dcu/admin/base/pytorch:1.13.1-centos7.6-dtk-23.04-py37-latest
```
获取最新的dtk并安装依赖
```
cd /opt
wget http://10.0.50.210:8000/jenkins/rocm/23.04.1/centos7/DTK-23.04.1-rc4-centos7-x86_64.tar.gz
tar -zxvf DTK-23.04.1-rc4-centos7-x86_64.tar.gz
source /opt/dtk-23.04.1/env.sh
cd mobilenet_prune
pip3 install -r requirements.txt
```

chenxj's avatar
chenxj committed
39
## 剪枝
sugon_cxj's avatar
sugon_cxj committed
40
41
42
43
44
45
46
47
48
49
50
51
efficientnet
```
python3 main.py --mode prune --model efficientnet --batch-size 128 --restore ./checkpoints/efficientnet.pt --dataset cifar10  --method l1 --speed-up 2.11 --global-pruning
```
mobilenetv2
```
python3 main.py --mode prune --model mobilenetv2 --batch-size 128 --restore ./checkpoints/mobilenetv2.pt --dataset cifar10  --method l1 --speed-up 2.11 --global-pruning
```
mobilenetv3
```
python3 main.py --mode prune --model mobilenetv3 --batch-size 128 --restore ./checkpoints/mobilenetv3.pt --dataset cifar10  --method l1 --speed-up 2.11 --global-pruning
```
chenxj's avatar
chenxj committed
52
## 测试
sugon_cxj's avatar
sugon_cxj committed
53
54
55
56
57
58
59
60
61
62
63
64
efficientnet
```
python3 main.py --mode test --model efficientnet --batch-size 128 --restore ./run/cifar10/prune/cifar10-global-l1-efficientnet/cifar10_efficientnet_l1.pt --dataset cifar10  --method l1 --speed-up 2.11 --global-pruning
```
mobilenetv2
```
python3 main.py --mode test --model mobilenetv2 --batch-size 128 --restore ./run/cifar10/prune/cifar10-global-l1-mobilenetv2/cifar10_mobilenetv2_l1.pt --dataset cifar10  --method l1 --speed-up 2.11 --global-pruning
```
mobilenetv3
```
python3 main.py --mode test --model mobilenetv3 --batch-size 128 --restore ./run/cifar10/prune/cifar10-global-l1-mobilenetv3/cifar10_mobilenetv3_l1.pt --dataset cifar10  --method l1 --speed-up 2.11 --global-pruning
```
chenxj's avatar
chenxj committed
65
66
## result
### 精度
sugon_cxj's avatar
sugon_cxj committed
67
method l1
chenxj's avatar
chenxj committed
68
69
70
71
72
| model | Base Acc | Pruned Acc | 
| :------: | :------: |:------: |
| efficientnet | 0.9300 | 0.9248 | 
| mobilenetv2 | 0.9222 | 0.9205 | 
| mobilenetv3 | 0.9034 | 0.8963 | 
sugon_cxj's avatar
sugon_cxj committed
73
74

method lamp
chenxj's avatar
chenxj committed
75
76
77
78
79
| model | Base Acc | Pruned Acc | 
| :------: | :------: |:------: |
| efficientnet | 0.9300 | 0.9256 | 
| mobilenetv2 | 0.9222 | 0.9225 | 
| mobilenetv3 | 0.9034 | 0.9044 | 
sugon_cxj's avatar
sugon_cxj committed
80
81

method group_norm
chenxj's avatar
chenxj committed
82
83
84
85
86
| model | Base Acc | Pruned Acc | 
| :------: | :------: |:------: |
| efficientnet | 0.9300 | 0.8977 | 
| mobilenetv2 | 0.9222 | 0.8953 | 
| mobilenetv3 | 0.9034 | 0.8852 | 
sugon_cxj's avatar
sugon_cxj committed
87

chenxj's avatar
chenxj committed
88
89
90
91
92
## 应用场景
### 算法类别
图像分类
### 热点应用行业
交通,金融,医疗,教育,家居
sugon_cxj's avatar
sugon_cxj committed
93
94
## 源码仓库及问题反馈
https://developer.hpccube.com/codes/modelzoo/mobilenet_prune
chenxj's avatar
chenxj committed
95
## 参考资料
sugon_cxj's avatar
sugon_cxj committed
96
* [Torch-Pruning](https://github.com/VainF/Torch-Pruning)
sugon_cxj's avatar
sugon_cxj committed
97