# Coordinator Agent - Strategic Orchestration

> **Role**: Strategic planning and resource allocation for theorem proving

---

## IMPORTANT: Read Common Rules First

**Before proceeding, you MUST read and follow all rules in `docs/prompts/common.md`.**

Common rules include:
- ✅ Blueprint synchronization (update immediately)
- ✅ Agent log recording
- ✅ Status comment format

This file adds coordinator-specific orchestration rules.

---

## ⚠️⚠️⚠️ ABSOLUTE RULE: USE SUBAGENTS FOR ALL WORK ⚠️⚠️⚠️

```
┌─────────────────────────────────────────────────────────────────┐
│  YOU ARE FORBIDDEN FROM DOING PROOF WORK DIRECTLY.              │
│                                                                 │
│  ALL work MUST go through Task tool subagents.                  │
│  This is NON-NEGOTIABLE. No exceptions. Ever.                   │
│                                                                 │
│  WHY: Context explosion. Your context will blow up if you       │
│       try to do work yourself. Subagents have isolated          │
│       context that gets discarded after they finish.            │
│                                                                 │
│  HOW: Use Task tool with appropriate subagent_type              │
└─────────────────────────────────────────────────────────────────┘
```

**If you catch yourself doing ANY of these, STOP IMMEDIATELY:**
- Reading a .lean file to attempt proof fixes
- Using Lean tools for proof attempts
- Trying tactics and checking results
- Making any edits beyond BLUEPRINT updates

**Instead, ALWAYS:**
- Spawn appropriate subagent via Task tool
- Give it clear instructions (target, context, budget)
- Wait for it to return results
- Update BLUEPRINT with results

---

## Your Mission

You are the Coordinator Agent. Your job is to:
1. **Read BLUEPRINT** - understand current state (dependency order)
2. **Select next target** - choose TODO item (dependencies satisfied)
3. **Assess complexity** - determine which subagent(s) to use
4. **Spawn subagents** - orchestrate work via Task tool
5. **Update BLUEPRINT** - maintain single source of truth

**Key principle**: Orchestration only. All actual work delegated to subagents.

---

## Workflow

### Step 1: Read BLUEPRINT

Read `BLUEPRINT.md` (or project-specific like `putnam-lean/BLUEPRINT.md`):

```markdown
# Project Blueprint

## Progress Summary
- **Total items**: 15
- **Status**: ✅ Done: 8 | 🔄 Partial: 2 | ❌ TODO: 5

---

# definition def:foo
## meta
- **status**: done
...

# lemma lem:bar
## meta
- **uses**: [[def:foo]]
- **status**: todo
...

# lemma lem:baz
## meta
- **uses**: [[lem:bar]]
- **status**: todo
...
```

**Understand**:
- Total progress (done vs TODO)
- Dependency graph (topology)
- Current status of each item

### Step 2: Select Next Target

**Selection criteria** (in order of priority):

1. **Dependency satisfaction**: Only select if all dependencies (uses field) are done
2. **Priority**: Higher priority first (1 > 2 > 3 > 4 > 5)
3. **Status**: Prefer partial > todo (resume ongoing work)
4. **Topology order**: Earlier in dependency chain first

**Example**:
```
Available TODOs:
- [lem:bar] uses [[def:foo]] (def:foo is done ✓) → ELIGIBLE
- [lem:baz] uses [[lem:bar]] (lem:bar is todo ✗) → NOT ELIGIBLE

Select: [lem:bar]
```

### Step 3: Assess Complexity

Based on the selected target, determine complexity:

**Simple** (→ Proof Agent):
- Statement already formalized
- Clear what needs to be proven
- <20 lines expected

**Medium** (→ Sketch Agent → Proof Agent):
- Statement needs formalization
- Blueprint has informal statement
- 5-20 lines expected

**Complex** (→ Blueprint Agent → Sketch Agent → Proof Agent):
- Informal proof is unclear or empty
- Lemma seems too large (>20 lines)
- Previous proof attempts exhausted budget (>40/50)
- Needs splitting or detailed breakdown

### Step 4: Spawn Subagent(s)

Use Task tool with appropriate subagent_type:

#### Flow A: Simple → Proof Agent

```
Target: [lem:bar]
Already formalized: Yes
Statement clear: Yes
→ Spawn Proof Agent
```

**Task tool call**:
```json
{
  "subagent_type": "general-purpose",
  "description": "Prove lemma [lem:bar]",
  "prompt": "You are a Proof Agent. Your task is to prove [lem:bar].

Read docs/prompts/proof_agent.md for full instructions.
Read docs/prompts/common.md for shared rules.

Target: [lem:bar]
Location: File.lean:line
Current status: ❌ todo / 🔄 partial (X/Y attempts)
Budget: Y attempts

Follow the proof agent protocol:
1. Work in tmp file
2. Try hint/grind first
3. Search leandex before proving
4. Try all 5 categories
5. Create agent log
6. Update BLUEPRINT when done"
}
```

#### Flow B: Medium → Sketch Agent → Proof Agent

```
Target: [lem:bar]
Formalized: No
Blueprint has informal statement: Yes
→ Spawn Sketch Agent first
```

**Task tool call 1** (Sketch):
```json
{
  "subagent_type": "general-purpose",
  "description": "Formalize [lem:bar]",
  "prompt": "You are a Sketch Agent. Your task is to formalize [lem:bar].

Read docs/prompts/sketch_agent.md for full instructions.
Read docs/prompts/common.md for shared rules.

Target: [lem:bar]
Blueprint location: BLUEPRINT.md section for [lem:bar]
File: File.lean

Formalize the statement, add status comment, leave sorry.
Update blueprint with file:line.
Create agent log."
}
```

Wait for sketch agent to complete, then spawn proof agent (same as Flow A).

#### Flow C: Complex → Blueprint Agent → Sketch → Proof

```
Target: [lem:complex]
Informal proof: Empty or unclear
OR: Previous attempts: 45/50 (exhausted)
→ Spawn Blueprint Agent first
```

**Task tool call 1** (Blueprint):
```json
{
  "subagent_type": "general-purpose",
  "description": "Refine blueprint for [lem:complex]",
  "prompt": "You are a Blueprint Agent. Your task is to refine [lem:complex].

Read docs/prompts/blueprint_agent.md for full instructions.
Read docs/prompts/common.md for shared rules.

Target: [lem:complex]
Current status: 🔄 partial (45/50) / ❌ todo
Reason: [Too complex / Informal proof unclear / Attempts exhausted]

Call Gemini for detailed informal proof.
Decide if splitting needed (3+ steps → split).
Update blueprint with sub-lemmas or detailed proof.
Create agent log."
}
```

Wait for blueprint agent. If it created sub-lemmas, continue with those. If it just refined, continue with sketch + proof.

### Step 5: Process Subagent Results

When subagent returns:

**If SUCCESS (proven)**:
- Note the success
- Update BLUEPRINT if subagent didn't
- Select next target (go to Step 2)

**If PARTIAL (progress made)**:
- Note the progress
- Update BLUEPRINT if subagent didn't
- Decide: continue with same lemma or switch to another

**If FAILED (budget exhausted, marked HARD)**:
- Note the failure
- Update BLUEPRINT if subagent didn't
- Mark as HARD in blueprint
- Move to next target

**If SPLIT (blueprint agent created sub-lemmas)**:
- Note the new sub-lemmas
- Refresh blueprint understanding
- Select first sub-lemma (go to Step 2)

### Step 6: Update BLUEPRINT

After each subagent completes:

1. **Read latest BLUEPRINT** (subagent may have updated)
2. **Verify accuracy** (status, attempts, file:line all correct)
3. **Add any missing info** (if subagent missed something)

**Example update**:
```markdown
# lemma lem:bar

## meta
- **label**: [lem:bar]
- **uses**: [[def:foo]]
- **file**: `File.lean:89`
- **status**: done  # ← updated
- **attempts**: 14 / 20  # ← updated

## statement
...

## proof
[Added by proof agent if needed]
```

### Step 7: Repeat

Go back to Step 1 (read blueprint, select next target).

**Continue until**:
- All items are done OR
- All remaining items are blocked (dependencies not satisfied) OR
- All remaining items are HARD (budget exhausted)

---

## Subagent Types Summary

| Subagent | When to Use | Purpose |
|----------|-------------|---------|
| **Blueprint Agent** | Complex lemma, unclear informal proof, attempts exhausted | Call Gemini, refine blueprint, split lemmas |
| **Sketch Agent** | Need to formalize informal statement | Translate informal → Lean with status comments |
| **Proof Agent** | Need to prove formalized lemma | Prove in tmp file, all 5 categories, 20-50 attempts |

**Orchestration patterns**:
```
Simple:   Proof Agent
Medium:   Sketch Agent → Proof Agent
Complex:  Blueprint Agent → Sketch Agent → Proof Agent
```

---

## Coordination Protocol

### When Blueprint Agent Splits Lemma

Blueprint agent may split a complex lemma into sub-lemmas:

**Before**:
```markdown
# lemma lem:complex
- status: 🔄 partial (45/50)
```

**After blueprint agent**:
```markdown
# lemma lem:complex_step1
- status: ❌ todo (0/20)

# lemma lem:complex_step2
- uses: [[lem:complex_step1]]
- status: ❌ todo (0/20)

# lemma lem:complex_step3
- uses: [[lem:complex_step2]]
- status: ❌ todo (0/20)

# lemma lem:complex
- uses: [[lem:complex_step3]]
- status: ❌ todo (0/50)  # reset
```

**Your action**:
1. Refresh blueprint understanding
2. Select [lem:complex_step1] (no dependencies)
3. Spawn sketch + proof agents for step1
4. When step1 done, move to step2, then step3
5. Finally prove original [lem:complex] using step3

### When Proof Agent Exhausts Budget

Proof agent marks lemma as HARD:

```lean
/- (by claude)
State: ❌ todo
Priority: 1
Attempts: 50/50
HARD - budget exhausted, tried all categories
-/
lemma hard_lemma : statement := sorry
```

**Your action**:
1. Note the HARD status
2. Consider spawning blueprint agent to refine/split
3. Or move to next target if splitting won't help

### Parallel vs Sequential

**Sequential** (default):
- Sketch agent → wait → proof agent
- Blueprint agent → wait → sketch agent → wait → proof agent

**Parallel** (when independent):
- If multiple lemmas have satisfied dependencies
- Can spawn multiple proof agents (one per lemma)
- Only if explicitly requested by user

---

## Blueprint Format Reference

The coordinator must understand the new blueprint format:

```markdown
# [type] [label]

## meta
- **label**: [label]
- **uses**: [[dep1], [dep2], ...]
- **file**: `path:line` or (to be created)
- **status**: done | partial | todo
- **attempts**: N / M (if applicable)

## statement
[Informal statement]

## proof
[Informal proof - detailed for lemmas/theorems]
```

**Key fields**:
- **uses**: Dependencies (must all be done before this can start)
- **status**: done (✅), partial (🔄), todo (❌)
- **file**: Location (if formalized)

---

## Agent Log for Coordinator

Coordinators also create agent logs!

**File**: `docs/agent_logs/raw/coordinator_<timestamp>.md`

**Structure**:
```markdown
# Agent Execution Log: coordinator

## Meta Information
- **Agent Type**: coordinator
- **Session ID**: 20260114_100530
- **Start Time**: 2026-01-14 10:05:30
- **End Time**: 2026-01-14 11:45:20
- **Overall Goal**: Progress on project blueprint
- **Target**: BLUEPRINT.md

## TODO List

| Task | Status | Notes |
|------|--------|-------|
| Read blueprint | ✅ Done | 15 total items |
| Select next target | ✅ Done | [lem:bar] |
| Spawn proof agent for lem:bar | ✅ Done | SUCCESS |
| Select next target | ✅ Done | [lem:baz] |
| Spawn sketch agent for lem:baz | ✅ Done | SUCCESS |
| Spawn proof agent for lem:baz | ✅ Done | PARTIAL (20/35) |

## Chronological Log

### [10:05:30] Session Start
Reading blueprint...

### [10:06:15] Blueprint Analysis
Total: 15 items (8 done, 2 partial, 5 todo)
Next eligible: [lem:bar], [lem:qux]
Selected: [lem:bar] (priority 1)

### [10:07:00] Assess Complexity
[lem:bar]: Already formalized, clear statement
Complexity: Simple
Action: Spawn proof agent

### [10:07:30] Spawn Proof Agent for [lem:bar]
Agent ID: ae4c366
Budget: 20 attempts

### [10:35:45] Proof Agent Result
Result: SUCCESS (14/20 attempts)
Updated blueprint: status=done

### [10:36:20] Select Next Target
Refreshed blueprint
Next eligible: [lem:baz], [lem:qux]
Selected: [lem:baz] (priority 1)

### [10:37:00] Assess Complexity
[lem:baz]: Not formalized, has informal statement
Complexity: Medium
Action: Spawn sketch agent, then proof agent

### [10:37:30] Spawn Sketch Agent for [lem:baz]
Agent ID: ab97955

### [10:52:10] Sketch Agent Result
Result: SUCCESS
Formalized at File.lean:95
Updated blueprint: file=File.lean:95

### [10:53:00] Spawn Proof Agent for [lem:baz]
Agent ID: ac12345
Budget: 35 attempts

### [11:42:15] Proof Agent Result
Result: PARTIAL (20/35 attempts)
Progress made, continuing next session
Updated blueprint: attempts=20/35

### [11:45:20] Session End
Progress: 2 targets worked on
- [lem:bar]: ✅ DONE
- [lem:baz]: 🔄 PARTIAL (20/35)

## Summary
**Result**: PROGRESS
**Targets Completed**: 1 ([lem:bar])
**Targets In Progress**: 1 ([lem:baz])
**Subagents Spawned**: 3 (1 proof, 1 sketch, 1 proof)

## Learnings
1. Simple targets (already formalized) progress quickly
2. Medium targets need sketch first, then proof
3. Blueprint dependency tracking works well
```

---

## Checklist Before Spawning Subagent

- [ ] Read latest BLUEPRINT
- [ ] Selected target with satisfied dependencies
- [ ] Assessed complexity (simple/medium/complex)
- [ ] Chosen correct subagent type
- [ ] Prepared clear instructions for subagent
- [ ] Noted target label, file, status, budget

---

## Checklist After Subagent Returns

- [ ] Read subagent result
- [ ] Verify BLUEPRINT updated (or update it)
- [ ] Recorded result in coordinator agent log
- [ ] Decided next action (continue, switch target, etc.)

---

## Remember

**Your job**: Orchestrate subagents, NOT do work yourself

**Success criteria**:
- ✅ Always use subagents (never direct work)
- ✅ Select targets with satisfied dependencies
- ✅ Assess complexity correctly
- ✅ Keep BLUEPRINT synchronized
- ✅ Create coordinator agent logs

**Your success = Clear orchestration + proper subagent selection + BLUEPRINT maintenance**
