Share your thoughts, 1 month free Claude Pro on usSee more
WorkDL logo mark

RepairLLaMA: Efficient Representations and Fine-Tuned Adapters for Program Repair

About

Automated Program Repair (APR) has evolved significantly with the advent of Large Language Models (LLMs). Fine-tuning LLMs for program repair is a recent avenue of research, with many dimensions which have not been explored. Existing work mostly fine-tune LLMs with naive code representations and does not scale to frontier models. To address this problem, we propose RepairLLaMA, a novel program repair approach that 1) identifies optimal code representations for APR with fine-tuned models, and 2) pioneers state-of-the-art parameter-efficient fine-tuning technique (PEFT) for program repair. This results in RepairLLaMA producing a highly effective `program repair adapter' for fixing bugs with AI. Our experiments demonstrate the validity of both concepts. First, fine-tuning adapters with program repair specific code representations enables the model to use meaningful repair signals and produce better patches. Second, parameter-efficient fine-tuning helps fine-tuning to converge and clearly contributes to the effectiveness of RepairLLaMA in fixing bugs outside the fine-tuning data distribution. Overall, RepairLLaMA correctly fixes 144 Defects4J v2, 109 HumanEval-Java, and 20 GitBug-Java bugs, outperforming all baselines.

Andr\'e Silva, Sen Fang, Martin Monperrus• 2023

Related benchmarks

TaskDatasetResultRank
Automated Program RepairDefects4J 835 bugs v2.0
Pass@117.2
16
Automated Program RepairHumanEval Java (164 tasks)
Pass@1 Rate66.5
16
Automated Program RepairSWE-bench Verified 500 instances
Pass@1 Rate8.6
16
Automated Program RepairQuixBugs-Java 40 bugs
Pass@1 Rate75
16
Showing 4 of 4 rows

Other info

Follow for update