SampleFix: Learning to Generate Functionally Diverse Fixes
Automatic program repair holds the potential of dramatically improving the productivity of programmers during the software development process and correctness of software in general. Recent advances in machine learning, deep learning, and NLP have rekindled the hope to eventually fully automate the...
Gespeichert in:
Hauptverfasser: | , , , |
---|---|
Format: | Artikel |
Sprache: | eng |
Schlagworte: | |
Online-Zugang: | Volltext bestellen |
Tags: |
Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
|
Zusammenfassung: | Automatic program repair holds the potential of dramatically improving the
productivity of programmers during the software development process and
correctness of software in general. Recent advances in machine learning, deep
learning, and NLP have rekindled the hope to eventually fully automate the
process of repairing programs. However, previous approaches that aim to predict
a single fix are prone to fail due to uncertainty about the true intend of the
programmer. Therefore, we propose a generative model that learns a distribution
over potential fixes. Our model is formulated as a deep conditional variational
autoencoder that can efficiently sample fixes for a given erroneous program. In
order to ensure diverse solutions, we propose a novel regularizer that
encourages diversity over a semantic embedding space. Our evaluations on common
programming errors show for the first time the generation of diverse fixes and
strong improvements over the state-of-the-art approaches by fixing up to 45% of
the erroneous programs. We additionally show that for the 65% of the repaired
programs, our approach was able to generate multiple programs with diverse
functionalities. |
---|---|
DOI: | 10.48550/arxiv.1906.10502 |