Score: 1

Program Synthesis from Partial Traces

Published: April 20, 2025 | arXiv ID: 2504.14480v3

By: Margarida Ferreira , Victor Nicolet , Joey Dodds and more

BigTech Affiliations: Amazon

Potential Business Impact:

Makes computers write code from examples.

Business Areas:
Application Performance Management Data and Analytics, Software

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.

Country of Origin
🇺🇸 United States

Page Count
46 pages

Category
Computer Science:
Programming Languages