Published July 6, 2024 | Version v1
Software Open

Automating Pruning in Top-Down Enumeration for Program Synthesis Problems with Monotonic Semantics

  • 1. ROR icon University of Wisconsin–Madison

Description

This is the artifact submission for OOPSLA'24 (R2) submission #377: Automating Pruning in Top-Down Enumeration for Program Synthesis Problems with Monotonic Semantics

Abstract

In top-down enumeration for program synthesis, abstraction-based pruning uses an abstract domain to approximate the set of possible values that a partial program, when completed, can output on a given input. If the set does not contain the desired output, the partial program and all its possible completions can be pruned. In its general form, abstraction-based pruning requires manually designed, domain-specific abstract domains and semantics, and thus has only been used in domain-specific synthesizers. This paper provides sufficient conditions under which a form of abstraction-based pruning can be automated for arbitrary synthesis problems in the general-purpose Semantics-Guided Synthesis (SemGuS) framework without requiring manually-defined abstract domains.We show that if the semantics of the language for which we are synthesizing programs exhibits some monotonicity properties, one can obtain an abstract interval-based semantics for free from the concrete semantics of the programming language, and use such semantics to effectively prune the search space. We also identify a condition that ensures such abstract semantics can be used to compute a precise abstraction of the set of values that a program derivable from a given hole in a partial program can produce. These precise abstractions make abstraction-based pruning more effective. We implement our approach in a tool, Moito, which can tackle synthesis problems defined in the SemGuS framework. Moito can automate interval-based pruning without any a-priori knowledge of the problem domain, and solve synthesis problems that previously required domain-specific, abstraction-based synthesizers—e.g., synthesis of regular expressions, CSV file schema, and imperative programs from examples.

Files

README.md

Files (742.2 MB)

Name Size Download all
md5:d5ca59c7fb1be170d52f682f28f3aad2
742.2 MB Preview Download
md5:fd781b022062c01e5e4708afb7dd6d3f
22.6 kB Preview Download