Skip to content

[ICML 2023] Code for "A Three-regime Model of Network Pruning"

License

Notifications You must be signed in to change notification settings

YefanZhou/ThreeRegimePruning

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Yefan Zhou, Yaoqing Yang, Arin Chang, Michael Mahoney

Introduction

We build a three-regime model by taxonomizing the global structure of the pruned NN loss landscape. Our model reveals that the dichotomous effect of high temperature is associated with transitions between distinct types of global structures in the post-pruned model. Our new insights lead to new practical approaches of hyperparameter tuning and model selection to improve pruning.
Please see the full paper on ArXiv.

Image description

(Figure 1 Overview of three-regime model.) The three regimes of pruning obtained by varying temperature-like parameters (in the dense pre-pruned model) and load-like parameters (in the sparse post-pruned model).

Image description

(Figure 2 Empirical Results.) Partitioning the 2D model density (load) – training epoch (temperature) diagram into three regimes. Models are trained with PreResNet-20 on CIFAR-10.

Installation

conda create -n three_regime python=3.8
conda activate three_regime
pip install -r requirements.txt
cd src
pip install -e .

Experiments

Generate the three-regime phase plots by varying temperature and load

cd src/three_regime_taxonomy/{training_epochs, batch_size}
python scripts/write_experiments.py \
            --ckpt-path {your_checkpoints_path} \
            --data-path {your_dataset_path} \
            --all \
            --earlystop-epoch-lst 10 20 ... 160 \         # Varying temperature via training epochs 
            # OR
            --batch-size-lst 16 32 ... 512 \              # Varying temperature via batch size
            # OR
            --optimizer 'SAM' --rho-lst 0.1 0.2 ... 0.8 \ # Varying temperature via SAM rho
            --prune-ratio-lst 0.95 0.94 ... 0.2 \         # Varying load via model density (pruning ratio)  
bash scripts/three_regime.sh

Notes: We use Slurm to parallelize the experiments, but didn't include the scripts for simplicity of code. Please adapt the code based on the parallelization mechanism that works for you.

Visualization

Download the provided checkpoints and metrics

bash download_ckpt.sh

Run the notebook to reproduce the Figure 2.

cd visualization
load_temperature_plots.ipynb

Acknowledgment

Thanks to the great open-source codebases rethinking-network-pruning, LAMP, loss_landscape_taxonomy.

Citation

We would appreciate it if you could cite the following paper if you found the repository useful for your work:

@inproceedings{zhou2023three,
  title={A Three-regime model of network pruning},
  author={Zhou, Yefan and Yang, Yaoqing and Chang, Arin and Mahoney W Michael},
  booktitle={International Conference on Machine Learning},
  year={2023}
}

About

[ICML 2023] Code for "A Three-regime Model of Network Pruning"

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published