CGP++ : A Modern C++ Implementation of Cartesian Genetic Programming
Roman Kalkreuth, Thomas Baeck
TL;DR
CGP++ presents the first version of a modern, object-oriented, generic C++ implementation of Cartesian Genetic Programming to address limitations of the original C reference and other implementations. It introduces a reusable architecture with advanced genetic variation, benchmarking interfaces, hyperparameter configuration, checkpointing, and concurrent evaluation, all guided by a design philosophy focused on interpretability and reproducibility. The work compares CGP++ to existing toolkits, discusses implementation challenges, and outlines future directions, including concurrency and vectorization, as well as expansion toward a general GP toolkit (GP++). Overall, CGP++ aims to broaden CGP applicability, facilitate experimentation, and provide a robust foundation for integrating new CGP techniques and problem domains.
Abstract
The reference implementation of Cartesian Genetic Programming (CGP) was written in the C programming language. C inherently follows a procedural programming paradigm, which entails challenges in providing a reusable and scalable implementation model for complex structures and methods. Moreover, due to the limiting factors of C, the reference implementation of CGP does not provide a generic framework and is therefore restricted to a set of predefined evaluation types. Besides the reference implementation, we also observe that other existing implementations are limited with respect to the features provided. In this work, we therefore propose the first version of a modern C++ implementation of CGP that pursues object-oriented design and generic programming paradigm to provide an efficient implementation model that can facilitate the discovery of new problem domains and the implementation of complex advanced methods that have been proposed for CGP over time. With the proposal of our new implementation, we aim to generally promote interpretability, accessibility and reproducibility in the field of CGP.
