Welcome to Pikaia β a Python package for evolutionary algorithms, genetic programming, and AI-driven optimization. This package is designed for researchers, students, and practitioners interested in evolutionary computation and data analysis.
- 𧬠Evolutionary simulation for data analysis
- π Built-in plotting and visualization
- π§© Modular, extensible strategy system (Dominant, Altruistic, Selfish, Balanced, Kin-Altruistic, Kin-Selfish, None)
- β‘ D-matrix accelerated iteration mode β typically 30β80Γ faster than standard iterative mode
- π Jupyter notebook examples included
- π¬ Scientific approach, ready for research and teaching
- β 99% test coverage
Install the package using pip:
pip install pikaiaFor local development, we recommend using UV, a fast Python package installer and resolver.
Clone the repository and navigate to the project directory:
git clone https://github.com/danube-ai/pikaia.git
cd pikaiaInstall UV using the official installer:
curl -LsSf https://astral.sh/uv/install.sh | shFor more installation options, visit the UV installation guide.
-
Create a virtual environment:
uv venv
-
Sync the dependencies (including development and notebook extras):
uv sync --extra dev --extra examples
-
Activate the virtual environment:
source .venv/bin/activateThis installs the package in editable mode along with tools for development (e.g., testing with pytest, linting with ruff) and Jupyter notebooks. The
uv synccommand ensures reproducible installations using the locked dependencies inuv.lock.
Here's a minimal example to get you started:
import numpy as np
from pikaia.data import PikaiaPopulation
from pikaia.models import PikaiaModel
from pikaia.schemas import GeneStrategyEnum, OrgStrategyEnum, MixStrategyEnum
from pikaia.strategies import GeneStrategyFactory, OrgStrategyFactory, MixStrategyFactory
# Prepare a small dataset (3 samples, 3 features)
data_3x3_raw = np.array([[300, 10, 2], [600, 5, 2], [1500, 4, 1]])
data_min = data_3x3_raw.min(axis=0)
data_max = data_3x3_raw.max(axis=0)
data_3x3_scaled = (data_3x3_raw - data_min) / (data_max - data_min)
population = PikaiaPopulation(data_3x3_scaled)
# Define strategies
gene_strategies = [
GeneStrategyFactory.get_strategy(GeneStrategyEnum.DOMINANT),
GeneStrategyFactory.get_strategy(GeneStrategyEnum.ALTRUISTIC),
]
org_strategies = [
OrgStrategyFactory.get_strategy(OrgStrategyEnum.BALANCED),
OrgStrategyFactory.get_strategy(OrgStrategyEnum.SELFISH),
]
gene_mix_strategy = org_mix_strategy = MixStrategyFactory.get_strategy(MixStrategyEnum.FIXED)
# Create and fit the model
model = PikaiaModel(
population=population,
gene_strategies=gene_strategies,
org_strategies=org_strategies,
gene_mix_strategy=gene_mix_strategy,
org_mix_strategy=org_mix_strategy,
max_iter=32,
)
model.fit()
print("Gene fitness history:", model.gene_fitness_history())For a significant speed-up on large populations, enable the D-matrix accelerated mode:
model = PikaiaModel(
population=population,
gene_strategies=gene_strategies,
org_strategies=org_strategies,
gene_mix_strategy=gene_mix_strategy,
org_mix_strategy=org_mix_strategy,
use_d_matrix=True, # 30β80Γ faster for compatible strategy combinations
max_iter=500,
)
model.fit()- Explore the
examples/directory for Jupyter notebooks, Python scripts, and data files. - See
examples/README.mdfor a full index of all examples. - See
examples/examples.ipynbfor a hands-on walkthrough or run individual example scripts likepython examples/example1.py. - See
examples/paper_example.pyfor the paper example script. - See
examples/d_matrix_comparison.pyto benchmark all 25 strategy combinations with D-matrix acceleration.
Genetic AI is a framework for evolutionary simulation and data analysis. In Genetic AI, a data problem is converted into a model of genes and organisms, and evolutionary simulations are run to gain insight into the input data.
- Genetic AI does not use training data to 'learn', but instead autonomously analyzes a problem using evolutionary strategies that capture behaviors and correlations in the data.
- This approach is useful for understanding complex datasets, optimization, and exploring emergent properties in data-driven systems.
Preprint: Genetic AI (arXiv)
- Philipp Wissgott (philipp@danube.ai)
- Andreas Roschal (andreas@danube.ai)
- Martin BΓ€r (martin@danube.ai)
- Carlos U. PΓ©rez Malla (carlos@danube.ai)
For questions, suggestions, or contributions, please feel free to open an issue.
This project is licensed under the terms of the MIT License. See the LICENSE file for details.
If you use Pikaia in your research, please cite our preprint:
@misc{wissgott2025geneticaievolutionarygames,
title={Genetic AI: Evolutionary Games for ab initio dynamic Multi-Objective Optimization},
author={Philipp Wissgott},
year={2025},
eprint={2501.19113},
archivePrefix={arXiv},
primaryClass={cs.NE},
url={https://arxiv.org/abs/2501.19113},
}Preprint: Genetic AI (arXiv)