English

ReACC: A Retrieval-Augmented Code Completion Framework

Software Engineering 2022-03-16 v1 Artificial Intelligence Computation and Language

Abstract

Code completion, which aims to predict the following code token(s) according to the code context, can improve the productivity of software development. Recent work has proved that statistical language modeling with transformers can greatly improve the performance in the code completion task via learning from large-scale source code datasets. However, current approaches focus only on code context within the file or project, i.e. internal context. Our distinction is utilizing "external" context, inspired by human behaviors of copying from the related code snippets when writing code. Specifically, we propose a retrieval-augmented code completion framework, leveraging both lexical copying and referring to code with similar semantics by retrieval. We adopt a stage-wise training approach that combines a source code retriever and an auto-regressive language model for programming language. We evaluate our approach in the code completion task in Python and Java programming languages, achieving a state-of-the-art performance on CodeXGLUE benchmark.

Keywords

Cite

@article{arxiv.2203.07722,
  title  = {ReACC: A Retrieval-Augmented Code Completion Framework},
  author = {Shuai Lu and Nan Duan and Hojae Han and Daya Guo and Seung-won Hwang and Alexey Svyatkovskiy},
  journal= {arXiv preprint arXiv:2203.07722},
  year   = {2022}
}

Comments

Published in ACL 2022