Synthesizing Specifications
Kanghee Park, Loris D'Antoni, Thomas Reps
TL;DR
The paper tackles automatic synthesis of precise specifications by introducing a customizable framework that takes a query $\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ {\\Phi}$ and a user-defined DSL $\ {\\mathcal{L}}$ to produce a best $\ {\\mathcal{L}}$-conjunction. It advances a counterexample-guided inductive synthesis approach that constructs incomparable best $\ {\\mathcal{L}}$-properties using positive and negative examples, with formal guarantees of soundness and precision under suitable language-structure assumptions. The authors implement Spyro in two modes (SMT-based and Sketch-based) and evaluate it on four applications: specification mining, modular algebraic specifications, sensitivity analysis, and enabling new abstract domains, demonstrating substantial performance and qualitative benefits, including discovering real bugs in modules. Overall, the work provides a flexible, provably correct pathway to extract highly precise, reusable specifications from code, with broad practical impact for verification, synthesis, and abstract interpretation.
Abstract
Every program should be accompanied by a specification that describes important aspects of the code's behavior, but writing good specifications is often harder than writing the code itself. This paper addresses the problem of synthesizing specifications automatically, guided by user-supplied inputs of two kinds: i) a query posed about a set of function definitions, and ii) a domain-specific language L in which the extracted property is to be expressed (we call properties in the language L-properties). Each of the property is a best L-property for the query: there is no other L-property that is strictly more precise. Furthermore, the set of synthesized L-properties is exhaustive: no more L-properties can be added to it to make the conjunction more precise. We implemented our method in a tool, Spyro. The ability to modify both the query and L provides a Spyro user with ways to customize the kind of specification to be synthesized. We use this ability to show that Spyro can be used in a variety of applications, such as mining program specifications, performing abstract-domain operations, and synthesizing algebraic properties of program modules.
