(Results of Latte with skip-branches on text-to-video and class-to-video tasks with Latte. Left: text-to-video with 1.7x and 2.0x speedup. Right: class-to-video with 2.2x and 2.4x speedup. Latency is measured on one A100.)
(Results of HunYuan-DiT with skip-branches on text-to-image task with Hunyuan-DiT. Latency is measured on one A100.)
This repository contains the official PyTorch implementation of the paper: Accelerating Vision Diffusion Transformers with Skip Branches. In this work, we enhance standard DiT models by introducing Skip-DiT, which incorporates skip branches to improve feature smoothness. We also propose Skip-Cache, which leverages skip branches to cache DiT features across timesteps during inference. The effectiveness of our approach is validated on various DiT backbones for both video and image generation, demonstrating how skip branches preserve generation quality while achieving significant speedup. Experimental results show that Skip-Cache provides a
Accelerating Vision Diffusion Transformers with Skip Branches
Guanjie Chen, Xinyu Zhao,Yucheng Zhou, Tianlong Chen, Yu Cheng
(contact us: [email protected], [email protected])
(🔥News) Dec 12, 2024🔥 Latte-Skip is now fully released 🎉, which is the First Text-to-Video Model with Skip-Branches, and can be accelerated 2x for free with Skip-Cache! You can generate videos with only 3 command lines!
latte-skip-cases.mp4
(🔥News) Nov 26, 2024🔥 The training and inference code for Skip-DiT is publicly available 🎉, along with all corresponding checkpoints (DiT-XL/2, FaceForensics, SkyTimelapse, UCF101, and Taichi-HD), which can be accessed here. Additionally, these models, including Hunyuan-DiT, are fully compatible with Skip-Cache for enhanced efficiency.
Illustration of Skip-DiT and Skip-Cache for DiT visual generation caching. (a) The vanilla DiT block for image and video generation. (b) Skip-DiT modifies the vanilla DiT model using skip branches to connect shallow and deep DiT blocks. (c) Given a Skip-DiT with
Feature smoothness analysis of DiT in the class-to-video generation task using DDPM. Normalized disturbances, controlled by strength coefficients
To generate videos with Latte-skip, you just need 3 steps
# 1. Prepare your conda environments
cd text-to-video ; conda env create -f environment.yaml ; conda activate latte
# 2. Download checkpoints of Latte and Latte-skip
python download.py
# 3. Generate videos with only one command line!
python sample/sample_t2v.py --config ./configs/t2v/t2v_sample_skip.yaml
# 4. (Optional) To accelerate generation with skip-cache, run following command
python sample/sample_t2v.py --config ./configs/t2v/t2v_sample_skip_cache.yaml --cache N2-700-50
In the same way, to generate images with Hunyuan-DiT, you only need 3 steps
# 1. Prepare your conda environments
cd text-to-image ; conda env create -f environment.yaml ; conda activate HunyuanDiT
# 2. Download checkpoints of Hunyuan-DiT
mkdir ckpts ; huggingface-cli download Tencent-Hunyuan/HunyuanDiT-v1.2 --local-dir ./ckpts
# 3. Generate images with only one command line!
python sample_t2i.py --prompt "渔舟唱晚" --no-enhance --infer-steps 100 --image-size 1024 1024
# 4. (Optional) To accelerate generation with skip-cache, run the following command
python sample_t2i.py --prompt "渔舟唱晚" --no-enhance --infer-steps 100 --image-size 1024 1024 --cache --cache-step 2
About the class-to-video and class-to-image task, you can found detailed instructions in class-to-video/README.md
and class-to-image/README.md
We have already released the training code of Latte-skip! It takes only a few days on 8 H100 GPUs. To train the text-to-video model:
- Prepare your text-video datasets and implement the
text-to-video/datasets/t2v_joint_dataset.py
- Run the two-stage training strategy:
- Freeze all the parameters except skip-branches. Set
freeze=True
intext-to-video/configs/train_t2v.yaml
. And then run the training scripts attext-to-video/train_scripts/t2v_joint_train_skip.sh
. - Overall training. Set
freeze=False
intext-to-video/configs/train_t2v.yaml
. And then run the training scripts. The text-to-video model we released is trained with only 300k text-video pairs of Vimeo for around 1 week on 8 H100 GPUs.
- Freeze all the parameters except skip-branches. Set
The training instructions of class-to-video
and text-to-video
tasks can be found in class-to-video/README.md
and class-to-image/README.md
Model | Task | Training Data | Backbone | Size(G) | Skip-Cache |
---|---|---|---|---|---|
Latte-skip | text-to-video | Vimeo | Latte | 8.76 | ✅ |
DiT-XL/2-skip | class-to-image | ImageNet | DiT-XL/2 | 11.40 | ✅ |
ucf101-skip | class-to-video | UCF101 | Latte | 2.77 | ✅ |
taichi-skip | class-to-video | Taichi-HD | Latte | 2.77 | ✅ |
skytimelapse-skip | class-to-video | SkyTimelapse | Latte | 2.77 | ✅ |
ffs-skip | class-to-video | FaceForensics | Latte | 2.77 | ✅ |
Pretrained text-to-image Model of HunYuan-DiT can be found in Huggingface and Tencent-cloud.
Skip-DiT has been greatly inspired by the following amazing works and teams: DeepCache, Latte, DiT, and HunYuan-DiT, we thank all the contributors for open-sourcing.
The code and model weights are licensed under LICENSE.