HOTGP -- Higher-Order Typed Genetic Programming

Program synthesis is the process of generating a computer program following a set of specifications, which can be a high-level description of the problem and/or a set of input-output examples. The synthesis can be modeled as a search problem in which the search space is the set of all the programs v...

Full description

Saved in:
Bibliographic Details
Published inarXiv.org
Main Authors Matheus Campos Fernandes, Fabrício Olivetti de França, Francesquini, Emilio
Format Paper Journal Article
LanguageEnglish
Published Ithaca Cornell University Library, arXiv.org 06.04.2023
Subjects
Online AccessGet full text

Cover

Loading…
More Information
Summary:Program synthesis is the process of generating a computer program following a set of specifications, which can be a high-level description of the problem and/or a set of input-output examples. The synthesis can be modeled as a search problem in which the search space is the set of all the programs valid under a grammar. As the search space is vast, brute force is usually not viable and search heuristics, such as genetic programming, also have difficulty navigating it without any guidance. In this paper we present HOTGP, a new genetic programming algorithm that synthesizes pure, typed, and functional programs. HOTGP leverages the knowledge provided by the rich data-types associated with the specification and the built-in grammar to constrain the search space and improve the performance of the synthesis. The grammar is based on Haskell's standard base library (the synthesized code can be directly compiled using any standard Haskell compiler) and includes support for higher-order functions, \(\lambda\)-functions, and parametric polymorphism. Experimental results show that, when compared to \(6\) state-of-the-art algorithms using a standard set of benchmarks, HOTGP is competitive and capable of synthesizing the correct programs more frequently than any other of the evaluated algorithms.
ISSN:2331-8422
DOI:10.48550/arxiv.2304.03200