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

You Only Cache Once: Decoder-Decoder Architectures for Language Models

About

We introduce a decoder-decoder architecture, YOCO, for large language models, which only caches key-value pairs once. It consists of two components, i.e., a cross-decoder stacked upon a self-decoder. The self-decoder efficiently encodes global key-value (KV) caches that are reused by the cross-decoder via cross-attention. The overall model behaves like a decoder-only Transformer, although YOCO only caches once. The design substantially reduces GPU memory demands, yet retains global attention capability. Additionally, the computation flow enables prefilling to early exit without changing the final output, thereby significantly speeding up the prefill stage. Experimental results demonstrate that YOCO achieves favorable performance compared to Transformer in various settings of scaling up model size and number of training tokens. We also extend YOCO to 1M context length with near-perfect needle retrieval accuracy. The profiling results show that YOCO improves inference memory, prefill latency, and throughput by orders of magnitude across context lengths and model sizes. Code is available at https://aka.ms/YOCO.

Yutao Sun, Li Dong, Yi Zhu, Shaohan Huang, Wenhui Wang, Shuming Ma, Quanlu Zhang, Jianyong Wang, Furu Wei• 2024

Related benchmarks

TaskDatasetResultRank
Multi-task Language UnderstandingLM Evaluation Harness (test)
ARC Challenge Acc42.92
24
Language ModelingWikiText v1 (test)
Perplexity13.65
18
Language ModelingFineWeb-Edu 500M-token (val)
Valid Loss2.244
18
Long-context Language UnderstandingRULER 128k
Average Score17.32
4
Showing 4 of 4 rows

Other info

Follow for update