Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

PyramidKV: Dynamic KV Cache Compression based on Pyramidal Information Funneling

About

In this study, we investigate whether attention-based information flow inside large language models (LLMs) is aggregated through noticeable patterns for long context processing. Our observations reveal that LLMs aggregate information through Pyramidal Information Funneling where attention is scattering widely in lower layers, progressively consolidating within specific contexts, and ultimately focusing on critical tokens (a.k.a massive activation or attention sink) in higher layers. Motivated by these insights, we developed PyramidKV, a novel and effective KV cache compression method. This approach dynamically adjusts the KV cache size across different layers, allocating more cache in lower layers and less in higher ones, diverging from traditional methods that maintain a uniform KV cache size. Our experimental evaluations, utilizing the LongBench benchmark, show that PyramidKV matches the performance of models with a full KV cache while retaining only 12% of the KV cache, thus significantly reducing memory usage. In scenarios emphasizing memory efficiency, where only 0.7% of the KV cache is maintained, PyramidKV surpasses other KV cache compression techniques, achieving up to a 20.5 absolute accuracy improvement on TREC dataset. In the Needle-in-a-Haystack experiment, PyramidKV outperforms competing methods in maintaining long-context comprehension in LLMs; notably, retaining just 128 KV cache entries enables the LLAMA-3-70B model to achieve 100.0 Acc. performance.

Zefan Cai, Yichi Zhang, Bofei Gao, Yuliang Liu, Yucheng Li, Tianyu Liu, Keming Lu, Wayne Xiong, Yue Dong, Junjie Hu, Wen Xiao• 2024

Related benchmarks

TaskDatasetResultRank
Long-context Language UnderstandingLongBench
M-Avg39.86
219
Long-context Language UnderstandingLongBench (test)
Average Score48.51
133
Long-context UnderstandingLongBench
Overall Average Score49.5
115
Long-context evaluationRULER 16k
Total Score70.68
59
Long-context Question AnsweringLongBench (test)
HotpotQA31.22
59
Needle-in-a-HaystackNeedle-in-a-Haystack
Accuracy96.2
44
Single-Doc Question AnsweringLongBench
MultifieldQA Score43.04
36
Long-context UnderstandingLongBench 1.0 (test)
NarrativeQA24.48
32
Long-context UnderstandingLongBench v0.2
Na.QA (NER QA)26.31
16
Question AnsweringBabilong 16k context length
QA1 Accuracy40
9
Showing 10 of 12 rows

Other info

Follow for update