# Evolutionary Analysis

Game-theoretic analysis of the program-equilibrium payoff matrix produced by
the Lean engine: ingestion of the matrix, Nash equilibrium enumeration with
exact rationals, cross-library verification, and structural classification.

## Layout

- `config.json` — Prisoner's Dilemma payoffs `(b, c)`, RNG seed, and the
  resolution chosen for the unresolved `(CupodBot, DupocBot)` cell.
- `data/` — input payoff matrix (`payoff_matrix.csv`) and a rendered view.
- `src/ingest/` — loads the raw action matrix and lifts entries to PD payoffs,
  applying the configured policy for undefined cells.
- `src/nash/` — Nash pipeline:
  - `game_construction.py`, `payoff_shift.py` — bimatrix assembly and positive
    shift for the enumeration backends.
  - `pure_ne.py`, `dominance.py` — pure NE and iterated strict dominance.
  - `method2_pygambit.py`, `method2_lrsnash.py` — extreme NE enumeration via
    two independent libraries.
  - `verification.py`, `classification.py`, `cooperation.py` — re-verification
    on the original payoffs, symmetry/component classification, and per-NE
    cooperation rates.
  - `cli.py` — end-to-end driver.
- `results/nash/` — per-run artifacts under `runs/<run_id>/` plus a `latest`
  symlink and `runs/INDEX.csv`.

## Run

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

Requires `pygambit` (Python) and an `lrsnash` binary on `PATH`. Override the
binary with `--lrsnash-bin` and the per-call timeout with
`--lrsnash-timeout-seconds`.

## Outputs

Each run writes to `results/nash/runs/<run_id>/`:

- `equilibria.jsonl`, `equilibria_summary.md` — extreme NE with rational and
  float strategies, payoffs, cooperation rate, classification, and the set of
  finders that discovered each one.
- `nash_components.json` — connected components of the extreme-NE set.
- `dominance_log.json` — iterated strict dominance trace.
- `verification_report.md` — best-response checks on the original `A`.
- `assumptions.json`, `provenance.json` — config, input SHA, library
  versions, and wallclock timings for reproducibility.

`results/nash/latest` points at the most recent run;
`results/nash/runs/INDEX.csv` is an append-only run index.
