Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

INTERVENOR: Prompting the Coding Ability of Large Language Models with the Interactive Chain of Repair

About

This paper introduces INTERVENOR (INTERactiVE chaiN Of Repair), a system designed to emulate the interactive code repair processes observed in humans, encompassing both code diagnosis and code repair. INTERVENOR prompts Large Language Models (LLMs) to play distinct roles during the code repair process, functioning as both a Code Learner and a Code Teacher. Specifically, the Code Learner is tasked with adhering to instructions to generate or repair code, while the Code Teacher is responsible for crafting a Chain-of-Repair (CoR) to serve as guidance for the Code Learner. During generating the CoR, the Code Teacher needs to check the generated codes from Code Learner and reassess how to address code bugs based on error feedback received from compilers. Experimental results demonstrate that INTERVENOR surpasses baseline models, exhibiting improvements of approximately 18% and 4.3% over GPT-3.5 in code generation and code translation tasks, respectively. Our further analyses show that CoR is effective to illuminate the reasons behind bugs and outline solution plans in natural language. With the feedback of code compilers, INTERVENOR can accurately identify syntax errors and assertion errors and provide precise instructions to repair codes. All data and codes are available at https://github.com/NEUIR/INTERVENOR

Hanbin Wang, Zhenghao Liu, Shuo Wang, Ganqu Cui, Ning Ding, Zhiyuan Liu, Ge Yu• 2023

Related benchmarks

TaskDatasetResultRank
Code GenerationHumanEval
Pass@175.6
850
Code GenerationMBPP
Pass@169.8
113
Code GenerationHumanEval-ET
Pass@154.8
75
Code GenerationMBPP-ET
Pass@147.1
75
Code GenerationHumanEval-X
Pass@1 (C++)67.1
20
Code GenerationHumanEval Python
Pass@175.6
18
Code GenerationMBPP Python
Pass@169.8
11
Code GenerationDS-1000 Python
Pass@139.7
7
Code TranslationHumanEval-X
Pass@1 (Python)89.8
4
Showing 9 of 9 rows

Other info

Code

Follow for update