A comprehensive survey on program synthesis with evolutionary algorithms

D Sobania, D Schweim… - IEEE Transactions on …, 2022 - ieeexplore.ieee.org
IEEE Transactions on Evolutionary Computation, 2022ieeexplore.ieee.org
The automatic generation of computer programs is one of the main applications with
practical relevance in the field of evolutionary computation. With program synthesis
techniques not only software developers could be supported in their everyday work but even
users without any programming knowledge could be empowered to automate repetitive
tasks and implement their own new functionality. In recent years, many novel program
synthesis approaches based on evolutionary algorithms have been proposed and evaluated …
The automatic generation of computer programs is one of the main applications with practical relevance in the field of evolutionary computation. With program synthesis techniques not only software developers could be supported in their everyday work but even users without any programming knowledge could be empowered to automate repetitive tasks and implement their own new functionality. In recent years, many novel program synthesis approaches based on evolutionary algorithms have been proposed and evaluated on common benchmark problems. Therefore, we identify and discuss in this survey the relevant evolutionary program synthesis approaches in the literature and provide an in-depth analysis of their performance. The most influential approaches we identify are stack-based, grammar-guided, as well as linear genetic programming (GP). For the stack-based approaches, we identify 37 in-scope papers, and for the grammar-guided and linear GP approaches, we identify 12 and 5 papers, respectively. Furthermore, we find that these approaches perform well on benchmark problems if there is a simple mapping from the given input to the correct output. On problems where this mapping is complex, e.g., if the problem consists of several subproblems or requires iteration/recursion for a correct solution, results tend to be worse. Consequently, for future work, we encourage researchers not only to use a program’s output for assessing the quality of a solution but also the way toward a solution (e.g., correctly solved subproblems).
ieeexplore.ieee.org