Bridging boolean and quantitative synthesis using smoothed proof search
S Chaudhuri, M Clochard, A Solar-Lezama - Proceedings of the 41st …, 2014 - dl.acm.org
S Chaudhuri, M Clochard, A Solar-Lezama
Proceedings of the 41st ACM SIGPLAN-SIGACT Symposium on Principles of …, 2014•dl.acm.orgWe present a new technique for parameter synthesis under boolean and quantitative
objectives. The input to the technique is a" sketch"---a program with missing numerical
parameters---and a probabilistic assumption about the program's inputs. The goal is to
automatically synthesize values for the parameters such that the resulting program
satisfies:(1) a {boolean specification}, which states that the program must meet certain
assertions, and (2) a {quantitative specification}, which assigns a real valued rating to every …
objectives. The input to the technique is a" sketch"---a program with missing numerical
parameters---and a probabilistic assumption about the program's inputs. The goal is to
automatically synthesize values for the parameters such that the resulting program
satisfies:(1) a {boolean specification}, which states that the program must meet certain
assertions, and (2) a {quantitative specification}, which assigns a real valued rating to every …
We present a new technique for parameter synthesis under boolean and quantitative objectives. The input to the technique is a "sketch" --- a program with missing numerical parameters --- and a probabilistic assumption about the program's inputs. The goal is to automatically synthesize values for the parameters such that the resulting program satisfies: (1) a {boolean specification}, which states that the program must meet certain assertions, and (2) a {quantitative specification}, which assigns a real valued rating to every program and which the synthesizer is expected to optimize.
Our method --- called smoothed proof search --- reduces this task to a sequence of unconstrained smooth optimization problems that are then solved numerically. By iteratively solving these problems, we obtain parameter values that get closer and closer to meeting the boolean specification; at the limit, we obtain values that provably meet the specification. The approximations are computed using a new notion of smoothing for program abstractions, where an abstract transformer is approximated by a function that is continuous according to a metric over abstract states.
We present a prototype implementation of our synthesis procedure, and experimental results on two benchmarks from the embedded control domain. The experiments demonstrate the benefits of smoothed proof search over an approach that does not meet the boolean and quantitative synthesis goals simultaneously.
ACM Digital Library