# PrisonersDilemma

Lean 4 formalization of Prisoner's Dilemma using fuel-bounded program evaluation.

This project provides a modular architecture to:

1. Define executable game programs using inductive syntax,
2. Evaluate programs under fuel constraints (to ensure termination),
3. Encode bot strategies with simulation, branching, and oracle reasoning,
4. Prove action and outcome claims via mechanized verification.

## Overview

The codebase is organized around a **fuel-bounded evaluator** for game programs:

- Program syntax and substitution in `PrisonersDilemma/Program.lean`,
- Fuelled evaluation semantics in `PrisonersDilemma/Dynamics.lean`,
- Bot strategy definitions in `PrisonersDilemma/Bots/`,
- Theorem developments and helpers in `PrisonersDilemma/Theorems/`.

The proving strategy focuses on outcome proofs:

1. Define bot strategies as `Prog` terms,
2. Establish guard evaluations and simulations,
3. Prove `play` (single action) and `outcome` (action pair) claims.

## Folder Map

### Library entrypoint

- `PrisonersDilemma.lean`
	- Root import hub for all build targets in the new package.

### Core semantics

- `PrisonersDilemma/Program.lean`
	- Defines `Action` (C or D), `Outcome` (action pair), and `Prog` inductive type.
	- `Prog` variants: `.const`, `.self`, `.opp`, `.sim`, `.ite`, `.search`.
	- Defines `Formula` for oracle-decidable propositions about programs.
	- Implements `Prog.subst` and `Formula.subst` for variable capture.

- `PrisonersDilemma/Dynamics.lean`
	- Defines fuel-bounded evaluator `eval : Nat → Prog → Prog → Prog → Option Action`.
	- Axiomatizes `proofSearch : Nat → Formula → Bool` (oracle).
	- Defines `play : Nat → Prog → Prog → Option Action` (single agent's move).
	- Defines `outcome : Nat → Prog → Prog → Option Outcome` (both agents' moves).
	- Defines `Formula.interp` (semantic interpretation of formulas).

### Bots and Theorems

- `PrisonersDilemma/Bots/`: a folder with 9 hand-written bots.
- `PrisornsDilemma/Theorems/`: a folder with all the intermediate and outcome proofs between the 9 bots.


## Build

From `engine/`:

```bash
# Build the entire package
lake build

# Build only PrisonersDilemma
lake build PrisonersDilemma

# Build a specific theorem module
lake build PrisonersDilemma.Theorems.OBot
```

**Toolchain:** Lean `v4.28.0` (see `lean-toolchain`).