zhaoting 4ec452149b | ||
---|---|---|
.. | ||
src | ||
Readme.md | ||
eval.py | ||
index.txt | ||
mindpsore_hub_conf.py |
Readme.md
Contents
- Adversarial Pruning Description
- Dataset
- Environment Requirements
- Script Description
- Model Description
- Description of Random Situation
- ModelZoo Homepage
Adversarial Pruning Description
The Adversarial Pruning method is a reliable neural network pruning algorithm by setting up a scientific control. We prefer to have a more rigorous research design by including a scientific control group as an essential part to minimize the effect of all factors except the association between the filter and expected network output. Acting as a control group, knockoff feature is generated to mimic the feature map produced by the network filter, but they are conditionally independent of the example label given the real feature map. Besides the real feature map on an intermediate layer, the corresponding knockoff feature is brought in as another auxiliary input signal for the subsequent layers.
Paper: Yehui Tang, Yunhe Wang, Yixing Xu, Dacheng Tao, Chunjing Xu, Chao Xu, Chang Xu. Scientific Control for Reliable Neural Network Pruning. Submitted to NeurIPS 2020.
Dataset
Dataset used: Oxford-IIIT Pet
-
step 1: Download dataset
-
step 2: Convert the dataset to mindrecord:
cd ./src python data_to_mindrecord_test.py
-
Dataset size: 7049 colorful images in 1000 classes
- Train: 3680 images
- Test: 3369 images
-
Data format: RGB images.
- Note: Data will be processed in src/dataset.py
Environment Requirements
- Hardware(Ascend/GPU)
- Prepare hardware environment with Ascend or GPU processor.
- Framework
- For more information, please check the resources below:
Script description
Script and sample code
├── Adversarial Pruning
├── Readme.md # descriptions about adversarial-pruning # shell script for evaluation with CPU, GPU or Ascend
├── src
│ ├──config.py # parameter configuration
│ ├──dataset.py # creating dataset
│ ├──resnet_imgnet.py # Pruned ResNet architecture
├── eval.py # evaluation script
├── index.txt # channel index of each layer after pruning
├── mindspore_hub_conf.py # export model for hub
Training process
To Be Done
Eval process
Usage
After installing MindSpore via the official website, you can start evaluation as follows:
Launch
# infer example
Ascend: python eval.py --dataset_path ~/Pets/test.mindrecord --platform Ascend --checkpoint_path [CHECKPOINT_PATH]
GPU: python eval.py --dataset_path ~/Pets/test.mindrecord --platform GPU --checkpoint_path [CHECKPOINT_PATH]
checkpoint can be produced in training process.
Result
result: {'acc': 0.8023984736985554} ckpt= ./resnet50-imgnet-0.65x-80.24.ckpt
Model Description
Performance
Evaluation Performance
ResNet50-0.65x on ImageNet2012
Parameters | |
---|---|
Model Version | ResNet50-0.65x |
uploaded Date | 09/10/2020 (month/day/year) ; |
MindSpore Version | 0.6.0-alpha |
Dataset | ImageNet2012 |
Parameters (M) | 14.6 |
FLOPs (G) | 2.1 |
Accuracy (Top1) | 75.80 |
ResNet50-0.65x on Oxford-IIIT Pet
Parameters | |
---|---|
Model Version | ResNet50-0.65x |
uploaded Date | 09/10/2020 (month/day/year) ; |
MindSpore Version | 0.6.0-alpha |
Dataset | Oxford-IIIT Pet |
Parameters (M) | 14.6 |
FLOPs (M) | 2.1 |
Accuracy (Top1) | 80.24 |
Description of Random Situation
In dataset.py, we set the seed inside “create_dataset" function. We also use random seed in train.py.
ModelZoo Homepage
Please check the official homepage.