The Fact Selection Problem in LLM-Based Program Repair
Nikhil Parasaram, Huijie Yan, Boyu Yang, Zineb Flahy, Abriele Qudsi, Damian Ziaber, Earl Barr, Sergey Mechtaev
TL;DR
The paper tackles the problem of selecting which bug-related facts to include in prompts for LLM-based automated program repair, showing that both the type and the number of facts impact success in a non-monotonic manner. It introduces seven bug-related facts (including angelic values) and conducts a large-scale study on 314 BugsInPy bugs, using over 19K prompts with GPT-3.5-Turbo-0125 and llama3-70B. It proves there is no universally optimal fact set and presents Maniple, a bug-tailored random-forest model that selects fact subsets to maximize prompt effectiveness; on a testing set of 157 bugs, Maniple repairs 88 bugs, about 17% more than the best generic configuration. The work highlights the importance of tailored prompt information in LLM-based program repair and provides datasets, code, and a practical method to guide future research in fact-selection strategies.
Abstract
Recent research has shown that incorporating bug-related facts, such as stack traces and GitHub issues, into prompts enhances the bug-fixing capabilities of large language models (LLMs). Considering the ever-increasing context window of these models, a critical question arises: what and how many facts should be included in prompts to maximise the chance of correctly fixing bugs? To answer this question, we conducted a large-scale study, employing over 19K prompts featuring various combinations of seven diverse facts to rectify 314 bugs from open-source Python projects within the BugsInPy benchmark. Our findings revealed that each fact, ranging from simple syntactic details like code context to semantic information previously unexplored in the context of LLMs such as angelic values, is beneficial. Specifically, each fact aids in fixing some bugs that would remain unresolved or only be fixed with a low success rate without it. Importantly, we discovered that the effectiveness of program repair prompts is non-monotonic over the number of used facts; using too many facts leads to subpar outcomes. These insights led us to define the fact selection problem: determining the optimal set of facts for inclusion in a prompt to maximise LLM's performance on a given task instance. We found that there is no one-size-fits-all set of facts for bug repair. Therefore, we developed a basic statistical model, named Maniple, which selects facts specific to a given bug to include in the prompt. This model significantly surpasses the performance of the best generic fact set. To underscore the significance of the fact selection problem, we benchmarked Maniple against the state-of-the-art zero-shot, non-conversational LLM-based bug repair methods. On our testing dataset of 157 bugs, Maniple repairs 88 bugs, 17% above the best configuration.
