Modelling Program Spaces in Program Synthesis with Constraints
By: Tilman Hinnerichs , Bart Swinkels , Jaap de Jong and more
Potential Business Impact:
Finds good computer programs much faster.
A core challenge in program synthesis is taming the large space of possible programs. Since program synthesis is essentially a combinatorial search, the community has sought to leverage powerful combinatorial constraint solvers. Here, constraints are used to express the program semantics, but not as a potentially potent tool to remove unwanted programs. Recent inductive logic programming approaches introduce constraints on the program's syntax to be synthesized. These syntactic constraints allow for checking and propagating a constraint without executing the program, and thus for arbitrary operators. In this work, we leverage syntactic constraints to model program spaces, defining not just solutions that are feasible, but also ones that are likely useful. To demonstrate this idea, we introduce BART, a solver that efficiently propagates and solves these constraints. We evaluate BART on program space enumeration tasks, finding that the constraints eliminate up to 99 percent of the program space, and that modeling program spaces significantly reduces enumeration time.
Similar Papers
GPU Accelerated Compact-Table Propagation
Artificial Intelligence
Makes computers solve big problems much faster.
Two Constraint Compilation Methods for Lifted Planning
Artificial Intelligence
Helps robots plan complex tasks faster.
Worst-Case Symbolic Constraints Analysis and Generalisation with Large Language Models
Software Engineering
Finds hidden software flaws by testing with tricky inputs.