Accelerating Diffusion Transformers with Dual Feature Caching

Chang Zou,Evelyn Zhang,Runlin Guo,Haohang Xu,Conghui He,Xuming Hu,Linfeng Zhang
2024-12-25
Abstract:Diffusion Transformers (DiT) have become the dominant methods in image and video generation yet still suffer substantial computational costs. As an effective approach for DiT acceleration, feature caching methods are designed to cache the features of DiT in previous timesteps and reuse them in the next timesteps, allowing us to skip the computation in the next timesteps. However, on the one hand, aggressively reusing all the features cached in previous timesteps leads to a severe drop in generation quality. On the other hand, conservatively caching only the features in the redundant layers or tokens but still computing the important ones successfully preserves the generation quality but results in reductions in acceleration ratios. Observing such a tradeoff between generation quality and acceleration performance, this paper begins by quantitatively studying the accumulated error from cached features. Surprisingly, we find that aggressive caching does not introduce significantly more caching errors in the caching step, and the conservative feature caching can fix the error introduced by aggressive caching. Thereby, we propose a dual caching strategy that adopts aggressive and conservative caching iteratively, leading to significant acceleration and high generation quality at the same time. Besides, we further introduce a V-caching strategy for token-wise conservative caching, which is compatible with flash attention and requires no training and calibration data. Our codes have been released in Github: \textbf{Code: \href{<a class="link-external link-https" href="https://github.com/Shenyi-Z/DuCa" rel="external noopener nofollow">this https URL</a>}{\texttt{\textcolor{cyan}{<a class="link-external link-https" href="https://github.com/Shenyi-Z/DuCa" rel="external noopener nofollow">this https URL</a>}}}}
Machine Learning,Artificial Intelligence,Computer Vision and Pattern Recognition
What problem does this paper attempt to address?