SECLJun 20, 2024

CodeRAG-Bench: Can Retrieval Augment Code Generation?

arXiv:2406.14497v2120 citations
Originality Incremental advance
AI Analysis

This addresses the problem of enhancing code generation for developers and researchers by systematically evaluating RAG's potential, though it is incremental as it builds on existing RAG methods applied to a new domain.

The paper tackles the problem of improving code generation by language models through retrieval-augmented generation (RAG), creating CodeRAG-Bench as a comprehensive benchmark with three task categories and five document sources. The result shows notable gains in code generation when retrieving high-quality contexts, but reveals current retrievers struggle with limited lexical overlap and generators fail with limited context lengths or integration abilities.

While language models (LMs) have proven remarkably adept at generating code, many programs are challenging for LMs to generate using their parametric knowledge alone. Providing external contexts such as library documentation can facilitate generating accurate and functional code. Despite the success of retrieval-augmented generation (RAG) in various text-oriented tasks, its potential for improving code generation remains under-explored. In this work, we conduct a systematic, large-scale analysis by asking: in what scenarios can retrieval benefit code generation models? and what challenges remain? We first curate a comprehensive evaluation benchmark, CodeRAG-Bench, encompassing three categories of code generation tasks, including basic programming, open-domain, and repository-level problems. We aggregate documents from five sources for models to retrieve contexts: competition solutions, online tutorials, library documentation, StackOverflow posts, and GitHub repositories. We examine top-performing models on CodeRAG-Bench by providing contexts retrieved from one or multiple sources. While notable gains are made in final code generation by retrieving high-quality contexts across various settings, our analysis reveals room for improvement -- current retrievers still struggle to fetch useful contexts especially with limited lexical overlap, and generators fail to improve with limited context lengths or abilities to integrate additional contexts. We hope CodeRAG-Bench serves as an effective testbed to encourage further development of advanced code-oriented RAG methods.

Code Implementations1 repo
Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes