# Open Source Game Theory

A Lean 4 formalization of Prisoner's Dilemma program-equilibrium models with a
Python orchestration layer that drives an LLM-assisted proof-writing pipeline, and an evolutionary analysis of the equilibria.

## Repository Layout

- `engine/` — Lean 4 project: program semantics, bots, and outcome theorems.
- `app/` — Python orchestration: generates Lean snippets, runs Lean checks,
  drives the agentic proof loop, and exposes a small FastAPI UI.
- `evolutionary/` — Game-theoretic analysis of the resulting payoff matrix:
  Nash equilibrium enumeration in exact rationals with cross-library
  verification (pygambit + lrsnash), classification into Nash components,
  and per-equilibrium cooperation rates. See `evolutionary/README.md`.

## What It Does

The Lean engine defines the game semantics and proofs. The Python app
automates matchups between programs by generating Lean code, running
`lake env lean`, and returning the resulting actions or outcome claims. It
also hosts an LLM-driven pipeline that synthesizes bots from natural-language
descriptions and proves their outcome theorems end-to-end. The evolutionary
layer takes the machine-checked action matrix produced by these matchups,
lifts it to Prisoner's Dilemma payoffs, and runs a verified Nash analysis
over the resulting symmetric game.

## Quick Start

### Lean engine

```bash
cd engine
lake build
```

### Python runner

```bash
cd app
uv sync
uv run pd-serve --reload
```

See `app/README.md` for the full CLI, the proof agent, and the API server.

### Evolutionary analysis

```bash
cd evolutionary
python -m src.nash.cli \
    --csv data/payoff_matrix.csv \
    --config config.json \
    --out-dir results/nash/
```

Requires `pygambit` and an `lrsnash` binary on `PATH`. See
`evolutionary/README.md` for the pipeline, outputs, and reproducibility
artifacts.

## Notes

- The Lean project is self-contained inside `engine/`.
- Generated Lean files and logs from the Python runner live under
  `app/generated/`.
- Each evolutionary run writes a fully reproducible bundle under
  `evolutionary/results/nash/runs/<run_id>/`, with a `latest` symlink and an
  append-only `INDEX.csv`.
