What Makes Good In-context Demonstrations for Code Intelligence Tasks with LLMs?
Shuzheng Gao, Xin-Cheng Wen, Cuiyun Gao, Wenxuan Wang, Hongyu Zhang, Michael R. Lyu
TL;DR
The paper tackles the sensitivity of in-context learning for code tasks to how demonstrations are constructed. Through an extensive empirical study across code summarization, bug fixing, and program synthesis, it analyzes demonstration selection, ordering, and quantity, using Codex, GPT-3.5, and ChatGPT. Key findings show that diversity and similarity-based instance-level demonstrations improve accuracy and stability, that ascending similarity-based ordering is generally advantageous, and that four demonstrations strike a practical balance given input-length limits. The work provides concrete guidelines for researchers and developers and demonstrates generalizability of the findings across multiple LLMs, highlighting future directions such as code representation improvements and broader task coverage.
Abstract
Pre-trained models of source code have gained widespread popularity in many code intelligence tasks. Recently, with the scaling of the model and corpus size, large language models have shown the ability of in-context learning (ICL). ICL employs task instructions and a few examples as demonstrations, and then inputs the demonstrations to the language models for making predictions. This new learning paradigm is training-free and has shown impressive performance in various natural language processing and code intelligence tasks. However, the performance of ICL heavily relies on the quality of demonstrations, e.g., the selected examples. It is important to systematically investigate how to construct a good demonstration for code-related tasks. In this paper, we empirically explore the impact of three key factors on the performance of ICL in code intelligence tasks: the selection, order, and number of demonstration examples. We conduct extensive experiments on three code intelligence tasks including code summarization, bug fixing, and program synthesis. Our experimental results demonstrate that all the above three factors dramatically impact the performance of ICL in code intelligence tasks. Additionally, we summarize our findings and provide takeaway suggestions on how to construct effective demonstrations, taking into account these three perspectives. We also show that a carefully-designed demonstration based on our findings can lead to substantial improvements over widely-used demonstration construction methods, e.g., improving BLEU-4, EM, and EM by at least 9.90%, 175.96%, and 50.81% on code summarization, bug fixing, and program synthesis, respectively
