Efficient Inference of Vision Instruction-Following Models with Elastic Cache
Zuyan Liu, Benlin Liu, Jiahui Wang, Yuhao Dong, Guangyi Chen, Yongming Rao, Ranjay Krishna, Jiwen Lu
TL;DR
This work tackles the memory and latency challenges of KV caches in multimodal instruction-following LVLMs by introducing Elastic Cache, a training-free, plug-and-play approach that separates acceleration strategies for instruction encoding and output generation. It relies on an importance-driven, layer-wise cache merging to prune redundancy during encoding and a fixed-point elimination strategy to bound cache growth during generation, guided by key equations such as $N_I = \gamma \cdot T$ and moment-to-moment retention controlled by a truncation point $N_{tl}$. Empirical results on LVLMs (e.g., LLaVA-1.5, Qwen-VL) show substantial speedups (up to approximately $77.9\%$ actual speedup) while maintaining or improving PPL and ROUGE metrics, outperforming baselines like H2O and Local across various KV budgets. The method demonstrates robustness for long, multimodal instruction-following tasks and offers practical impact for real-world systems by reducing memory demands without retraining, though it relies on attention-based importance signals and raises considerations for societal impact in deployment.
Abstract
In the field of instruction-following large vision-language models (LVLMs), the efficient deployment of these models faces challenges, notably due to the high memory demands of their key-value (KV) caches. Conventional cache management strategies for LLMs focus on cache eviction, which often fails to address the specific needs of multimodal instruction-following models. Recognizing this gap, in this paper, we introduce Elastic Cache, a novel approach that benefits from applying distinct acceleration methods for instruction encoding and output generation stages. We investigate the metrics of importance in different stages and propose an importance-driven cache merging strategy to prune redundancy caches. Instead of discarding less important caches, our strategy identifies important key/value vectors as anchor points. Surrounding less important caches are then merged with these anchors, enhancing the preservation of contextual information in the KV caches while yielding an arbitrary acceleration ratio. For instruction encoding, we utilize the frequency to evaluate the importance of caches. Regarding output generation, we prioritize tokens based on their distance with an offset, by which both the initial and most recent tokens are retained. Results on a range of LVLMs demonstrate that Elastic Cache not only boosts efficiency but also notably outperforms existing pruning methods in language generation across various tasks. Code is available at https://github.com/liuzuyan/ElasticCache
