Metadata-Version: 2.4
Name: ezga-lib
Version: 0.0.49
Summary: A modular multi-objective genetic algorithm framework for atomistic structure exploration
Project-URL: Homepage, https://thgitlab.rz-berlin.mpg.de/lombardi/ezga
Project-URL: Issues, https://thgitlab.rz-berlin.mpg.de/lombardi/ezga/issues
Author-email: Juan Manuel Lombardi <lombardi@fhi-berlin.mpg.de>
License: GPL-3.0-only
Keywords: DFT,MLIP,genetic algorithm,materials,multi-objective
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Scientific/Engineering :: Chemistry
Classifier: Topic :: Scientific/Engineering :: Physics
Requires-Python: >=3.10
Requires-Dist: ase>=3.22.1
Requires-Dist: matplotlib>=3.4
Requires-Dist: numpy>=1.26
Requires-Dist: psutil>=5.9
Requires-Dist: pydantic>=2.10
Requires-Dist: rich>=13.0
Requires-Dist: ruamel-yaml>=0.18
Requires-Dist: sage-lib>=0.1.6.3
Requires-Dist: scikit-learn>=1.4
Requires-Dist: scipy>=1.12
Requires-Dist: spglib
Requires-Dist: typer>=0.12
Requires-Dist: typing-extensions>=4.6
Provides-Extra: tests
Requires-Dist: pytest-cov>=4; extra == 'tests'
Requires-Dist: pytest>=7; extra == 'tests'
Description-Content-Type: text/markdown

# EZGA — Evolutionary Structure Exploration Framework

## Overview

EZGA is a modular, scalable, and chemically aware evolutionary framework for exploring and optimizing atomistic structures. It follows the **GitLab Enterprise Documentation Style**, emphasizing clarity, task‑orientation, operational guidance, and maintainability. This page serves as the primary landing document for new users and contributors.

EZGA enables configuration‑first evolutionary searches across molecular, cluster, crystalline, and surface systems. The engine integrates interchangeable components—initialization, features, objectives, selection, variation, convergence, and simulation—built around reproducible workflows and deterministic archival.

---

## Key capabilities

* **Configuration‑driven GA engine** for molecules and periodic crystals.
* **Composable modules**: initialization, constraints, features, objectives, selection, variation, simulator, convergence.
* **Robust execution**: deterministic seeds, deduplication, integrity checks, scalable parallelism.
* **Physical‑model integration** with ASE/MACE or any Python‑callable evaluator.
* **Hierarchical Supercell Escalation (HiSE)** for periodic systems.
* **Task‑oriented workflows**: copy → modify → run.

---

## Why use EZGA

* Explore large compositional/structural spaces efficiently.
* Apply human‑readable constraints (e.g., `greater_than("Cu", 1)`).
* Start with datasets or DoE space‑filling seeds; escalate to larger supercells.
* Increase robustness using integrity checks that avoid unphysical trial structures.
* Scale seamlessly from a laptop to multi‑GPU clusters.

---

## Get started fast

### 1. Install (Python ≥ 3.10)

```bash
pip install ezga_lib
```

Optional GPU/ML potential dependencies (MACE/ASE, CUDA/ROCm) depend on your environment.
See **Simulator** in the Wiki.

### 2. Smoke test

```python
import ezga
print(getattr(ezga, "__version__", "unknown"))
```

### 3. Run your first job

Follow the minimal runnable script in **Quickstart**.

**Tip:** In GitLab Wiki, section anchors work like: `./Constraints#greater-than`.

---

## Documentation

Full documentation is available in the project's **GitLab Wiki**:

* **[Home](./-/wikis/home)**
* **[Installation](./-/wikis/Installation)**
* **[Quickstart](./-/wikis/Quickstart)**
* **[Recipes](./-/wikis/Recipes)**
* **[Configuration (GAConfig)](./-/wikis/Configuration)**

---

## Repository structure

```
src/ezga/
    core/                   # GA engine
    selection/              # Parent selectors
    variation/              # Mutation & crossover operators
    hise/                   # Supercell escalation
    thermostat/             # Exploration–exploitation control
    DoE/                    # Design-of-Experiments initializer
    bayesian_optimization/  # Surrogate-driven generative module
    convergence/            # Termination logic
    simulator/              # MD, relaxations, MLIPs
    evaluator/              # Feature & objective metrics
    visualization/
    sync/                   # Island-model mailbox
    io/                     # SQL–HDF5 state storage
    cli/                    # Command-line interface
    utils/

docs/                       # Sphinx documentation
tests/                      # Regression tests
dist/                       # Build artifacts
examples/                   # Example workflows
```

---

## Usage

### YAML workflow

```bash
ezga run config.yaml
```

### Python API

```python
from ezga import Agent, load_config
config = load_config("config.yaml")
agent = Agent(config)
agent.run()
```

---

## Benchmarks

EZGA is validated on:

* Molecular conformational exploration (alanine dipeptide).
* Lennard–Jones cluster global search.
* Binary‑oxide convex‑hull reconstruction.
* Autonomous CuO/Cu₂O grand‑canonical phase diagram.

---

## Issues & Support

Use the GitLab **Issues** board to report problems, request enhancements, or ask questions:

* **[Report a bug](./-/issues/new?issue_type=bug)**
* **[Request a feature](./-/issues/new?issue_type=feature)**
* **[Ask for clarification](./-/issues)**
* **[Suggest documentation improvements](./-/issues)**

Issue templates (if configured) are available here:
**[Issue templates](./-/issues/templates)**

---

## Authors

* Juan Manuel Lombardi
* Felix Riccius
* Charles W. P. Paré
* Karsten Reuter
* Christoph Scheurer

