Program Synthesis from Partial Traces
By: Margarida Ferreira , Victor Nicolet , Joey Dodds and more
Potential Business Impact:
Makes computers write code from examples.
We present the first technique to synthesize programs that compose side-effecting functions, pure functions, and control flow, from partial traces containing records of only the side-effecting functions. This technique can be applied to synthesize API composing scripts from logs of calls made to those APIs, or a script from traces of system calls made by a workload, for example. All of the provided traces are positive examples, meaning that they describe desired behavior. Our approach does not require negative examples. Instead, it generalizes over the examples and uses cost metrics to prevent over-generalization. Because the problem is too complex for traditional monolithic program synthesis techniques, we propose a new combination of optimizing rewrites and syntax-guided program synthesis. The resulting program is correct by construction, so its output will always be able to reproduce the input traces. We evaluate the quality of the programs synthesized when considering various optimization metrics and the synthesizer's efficiency on real-world benchmarks. The results show that our approach can generate useful real-world programs.
Similar Papers
Program Synthesis via Test-Time Transduction
Artificial Intelligence
Teaches computers to write code from examples.
Synthesiz3 This: an SMT-Based Approach for Synthesis with Uncomputable Symbols
Logic in Computer Science
Makes computers write code from math problems.
From Traces to Program Incorrectness: A Type-Theoretic Approach
Programming Languages
Finds bugs in computer programs by watching how they work.