Skip to content

Latest commit

 

History

History
64 lines (46 loc) · 3.88 KB

README.md

File metadata and controls

64 lines (46 loc) · 3.88 KB

DiP-GO: A Dffusion Pruner via Few-step Gradient Optimization (NeurIPS 2024)

This is the unofficial repository of DiP-GO: A Dffusion Pruner via Few-step Gradient Optimization.


1. Highlights

intro figure main figure

Abstract: Diffusion models have achieved remarkable progress in the field of image generation due to their outstanding capabilities. However, these models require substantial computing resources because of the multi-step denoising process during inference. While traditional pruning methods have been employed to optimize these models, the retraining process necessitates large-scale training datasets and extensive computational costs to maintain generalization ability, making it neither convenient nor efficient. Recent studies attempt to utilize the similarity of features across adjacent denoising stages to reduce computational costs through simple and static strategies. However, these strategies cannot fully harness the potential of the similar feature patterns across adjacent timesteps. In this work, we propose a novel pruning method that derives an efficient diffusion model via a more intelligent and differentiable pruner. At the core of our approach is casting the model pruning process into a SubNet search process. Specifically, we first introduce a SuperNet based on standard diffusion via adding some backup connections built upon the similar features. We then construct a plugin pruner network and design optimization losses to identify redundant computation. Finally, our method can identify an optimal SubNet through few-step gradient optimization and a simple post-processing procedure. We conduct extensive experiments on various diffusion models including Stable Diffusion series and DiTs. Our DiP-GO approach achieves 4.4x speedup for SD-1.5 without any loss of accuracy, significantly outperforming the previous state-of-the-art methods.


2. Main Contributions

  1. We define a SuperNet based on standard diffusion and show how to obtain a SubNet. This transforms the diffusion optimization problem into an efficient SubNet search process without the need for retraining pretraind diffusion models.
  2. We design a plugin pruner tailored specifically for diffusion models. This pruner optimizes pruning constraints while maximizing synthesis capability. Additionally, we introduce a post-processing method for the pruner to ensure that the SubNet meets specified pruning requirements.
  3. We conduct extensive pruning experiments across various diffusion models, including Stable Diffusion 1.5, Stable Diffusion 2.1, Stable Diffusion XL, and DiT. Extensive experiments demonstrate the superiority of our method, achieving a notable 4.4 $\times$ speedup during inference on Stable Diffusion 1.5 without the need for retraining the diffusion model.

3. Method Pipeline

main figure

Please refer to the paper for more technical details.


4. How to Run Experiments?

  • We provide the training, evaluating, testing guideline of DiP-GO on SD-1.5 as below:

Train

  • Run the training script.
 bash src/scripts/train_sd15.sh [GPU_ID]

Eval

  • Run the evaluating script on CoCo / Parti.
 bash src/scripts/eval_sd15.sh [GPU_ID]

Run the demo

 python demo_sd15.py

Citation

If you find our work inspiring in your research, please cite our work.

@article{zhu2024dipgodiffusionprunerfewstep,
  title={DiP-GO: A Diffusion Pruner via Few-step Gradient Optimization},
  author={Haowei Zhu and Dehua Tang and Ji Liu and Mingjie Lu and Jintu Zheng and Jinzhang Peng and Dong Li and Yu Wang and Fan Jiang and Lu Tian and Spandan Tiwari and Ashish Sirasao and Jun-Hai Yong and Bin Wang and Emad Barsoum},
  journal={arXiv preprint arXiv:2410.16942},
  year={2024}
}