## Table 1

| Claim Type | Self-Verification Sufficient? | Why |
| :--- | :--- | :--- |
| Liberty/atari count | Yes, with board simulation | Mechanically decidable, no estimation error |
| Ladder/net sequence | Yes, with step-by-step tracing | Deterministic tree search |
| Group life-and-death status | Partially — easy cases yes | Hard cases require deep search; model errors correlate with generation errors |
| Territory estimate | No | Requires understanding of influence and boundary disputes, highly model-error-prone |
| "This move is urgent" / "sente" claims | No | Requires comparative win-rate evaluation across candidate moves |

## Table 2

| Field | Type | Description |
| :--- | :--- | :--- |
| `Gk.color` | enum: `black`, `white` | Stone color |
| `Gk.anchor` | string: coordinate | Identifier stone |
| `Gk.liberties` | int 0–8 | Exact liberty count |
| `Gk.in_atari` | bool | liberties == 1 |
| `Gk.size` | int | Number of stones in group |
| `Gk.connected_to_edge` | bool | Whether stone touches board edge |
| `Gk.is_key_group` | bool | Assessment of centrality |
| `ladder_exists` | bool | Ladder fight present |
| `ladder_favor` | enum: `black`, `white`, `none` | Who wins the ladder |
| `ko_active` | bool | Ko fight active |
| `capture_race_exists` | bool | Semeai present |
| `capture_race_favor` | enum: `black`, `white`, `even`, `none` | Who wins the capture race |

## Table 3

| Field | Type | Description |
| :--- | :--- | :--- |
| `focus_move_pattern` | string or `null` | boardmatcher `nameMove()` |
| `focus_shape_type` | string or `null` | boardmatcher `findPatternInMove()` |

## Table 4

| Field | KataGo source | Description |
| :--- | :--- | :--- |
| `game_phase` | `rawVarTimeLeft` | opening, middlegame, endgame |
| `position_sharpness` | `rawStWrError` | sharp, normal, quiet |
| `score_uncertainty` | `scoreStdev` | high, medium, low |
| `focus_region` | Model-selected | Region of relevance |
| `focus_urgency` | composite | high, medium, low |
| `focus_ownership_balance` | `ownership` sum | Net ownership, bucketed to 0.5 |
| `focus_ownership_uncertainty` | `ownershipStdev` sum | high, medium, low |
| `Gk.ownership_confidence` | `ownershipStdev` mean | settled, contested |
| `Gk.status` | ownership + stdev | alive, dead, unsettled |
| `best_move_utility` | `moveInfos[0].utility` | Bucketed to 0.01 |
| `utility_gap` | utility diff | large, medium, small |
| `best_move_score_delta` | scoreLead diff | Bucketed to 0.5 |
| `global_black_score_lead` | `rootInfo.scoreLead` | Bucketed to 0.5 |
| `global_black_winrate` | `rootInfo.winrate` | Bucketed to 1% |

## Table 5

| Field | Rule |
| :--- | :--- |
| `position_sharpness` | rawStWrError: > 0.06 → sharp, 0.02–0.06 → normal, < 0.02 → quiet |
| `score_uncertainty` | scoreStdev: > 20 → high, 10–20 → medium, < 10 → low |
| `focus_urgency` | ownershipStdev region sum > 5 and rawStWrError > 0.03 → high; either → medium; neither → low |
| `focus_ownership_uncertainty` | ownershipStdev region sum: > 5 → high, 2–5 → medium, < 2 → low |
| `Gk.ownership_confidence` | ownershipStdev mean over group: > 0.2 → contested, ≤ 0.2 → settled |
| `Gk.status` | ownership mean > 0.7 (correct color) and stdev < 0.2 → alive; mean < −0.3 → dead; otherwise unsettled |
| `utility_gap` | diff > 0.1 → large, 0.03–0.1 → medium, < 0.03 → small |
| `game_phase` | rawVarTimeLeft: > 60 → opening, 20–60 → middlegame, < 20 → endgame |

## Table 6

| Scenario | Score |
| :--- | :--- |
| Tool called, claim matches tool response | +1.0 × weight |
| Tool not called, claim correct per post-hoc engine check | +0.5 × weight |
| Tool not called, claim incorrect | −0.5 × weight |
| Tool called, claim contradicts tool response | −1.5 × weight |
| boardmatcher called, claim matches | +1.0 × weight |
| boardmatcher called, claim doesn't match | −0.5 × weight |
| boardmatcher not called, claim matches post-hoc | +0.3 × weight |

## Table 7

| Field | Weight |
| :--- | :--- |
| `Gk.in_atari` | 0.16 |
| `Gk.liberties` | 0.12 |
| `ladder_exists` + `ladder_favor` | 0.16 |
| `ko_active` | 0.08 |
| `Gk.status` | 0.12 |
| `capture_race_exists` + `capture_race_favor` | 0.12 |
| `Gk.size` | 0.06 |
| `Gk.connected_to_edge` | 0.06 |
| `focus_move_pattern` | 0.08 |
| `focus_shape_type` | 0.04 |

## Table 8

| Field | Weight |
| :--- | :--- |
| `score_uncertainty` | 0.20 |
| `position_sharpness` | 0.20 |
| `focus_urgency` | 0.20 |
| `focus_ownership_uncertainty` | 0.20 |
| `game_phase` | 0.10 |
| `utility_gap` | 0.10 |

## Table 9

| Field | Perturbation |
| :--- | :--- |
| `G1.in_atari` | flip bool; adjust liberties |
| `ladder_exists` | flip bool; if false, set `ladder_favor = none` |
| `focus_ownership_uncertainty` | `high` ↔ `low`; `medium` unchanged |
| `position_sharpness` | `sharp` ↔ `quiet`; `normal` unchanged |
| `utility_gap` | `large` ↔ `small`; `medium` unchanged |

## Table 10

| Pass | v0.2 budget | v0.3 budget | Reason |
| :--- | :--- | :--- | :--- |
| Pass 1 max tokens | 768 | 1024 | Prose interleaved with tags adds ~250 tokens |
| Pass 2 max tokens | 256 | 256 | Unchanged |

## Table 11

| Parameter | v0.3 value |
| :--- | :--- |
| Max Pass 1 tokens | 1024 |
| Max Pass 2 tokens | 256 |
| Group size G | 6 |
| Learning rate | 5e-6 |
| KL coefficient β | 0.04 |
| Reference model | Qwen3-8B-Instruct frozen |
| Training steps | 500–1000 |
| Warmup steps | 50 |
| Counterfactual fields per rollout | 5 |

## Table 12

| Source | Fraction |
| :--- | :--- |
| Professional game corpora | 40% |
| Synthetic critical positions (KataGo-filtered) | 40% |
| LoGos training positions with low explanation fidelity | 20% |

## Table 13

| Phase | Estimated time |
| :--- | :--- |
| KataGo pre-analysis (800 visits) | ~2 hours |
| boardmatcher pre-computation | ~30 minutes |
| SFT cold-start (1000 demos, 2 epochs) | ~2–3 hours |
| RL training (500 steps, G=6, 5 cf, 1024 tokens) | ~20–28 hours |
| Evaluation + human review sample | ~3 hours |
| **Total** | **~28–36 hours** |
