Program Synthesis in Saturation

Petra Hozzová,Laura Kovács,Chase Norman,Andrei Voronkov
DOI: https://doi.org/10.1007/978-3-031-38499-8_18
2024-02-29
Abstract:We present an automated reasoning framework for synthesizing recursion-free programs using saturation-based theorem proving. Given a functional specification encoded as a first-order logical formula, we use a first-order theorem prover to both establish validity of this formula and discover program fragments satisfying the specification. As a result, when deriving a proof of program correctness, we also synthesize a program that is correct with respect to the given specification. We describe properties of the calculus that a saturation-based prover capable of synthesis should employ, and extend the superposition calculus in a corresponding way. We implemented our work in the first-order prover Vampire, extending the successful applicability of first-order proving to program synthesis.
Logic in Computer Science
What problem does this paper attempt to address?