Specification-Guided Repair of Arithmetic Errors in Dafny Programs using LLMs
By: Valentina Wu, Alexandra Mendes, Alexandre Abreu
Potential Business Impact:
Fixes computer code errors automatically using smart AI.
Debugging and repairing faults when programs fail to formally verify can be complex and time-consuming. Automated Program Repair (APR) can ease this burden by automatically identifying and fixing faults. However, traditional APR techniques often rely on test suites for validation, but these may not capture all possible scenarios. In contrast, formal specifications provide strong correctness criteria, enabling more effective automated repair. In this paper, we present an APR tool for Dafny, a verification-aware programming language that uses formal specifications - including pre-conditions, post-conditions, and invariants - as oracles for fault localization and repair. Assuming the correctness of the specifications and focusing on arithmetic bugs, we localize faults through a series of steps, which include using Hoare logic to determine the state of each statement within the program, and applying Large Language Models (LLMs) to synthesize candidate fixes. The models considered are GPT-4o mini, Llama 3, Mistral 7B, and Llemma 7B. We evaluate our approach using DafnyBench, a benchmark of real-world Dafny programs. Our tool achieves 89.6% fault localization coverage and GPT-4o mini yields the highest repair success rate of 74.18%. These results highlight the potential of combining formal reasoning with LLM-based program synthesis for automated program repair.
Similar Papers
Specification-Guided Repair of Arithmetic Errors in Dafny Programs using LLMs
Software Engineering
Fixes computer code errors using smart guessing.
Empirical Evaluation of Generalizable Automated Program Repair with Large Language Models
Software Engineering
Fixes computer code bugs automatically across languages.
Do AI models help produce verified bug fixes?
Software Engineering
Fixes computer code bugs automatically and reliably.