# Stage-0 Probe (No Task / No Labels / No Training)

This probe is a **physics-style** diagnostic for the OLL “scalar echo” approximation in a **pure dynamical regime**:

- Untrained tanh RNN
- Random recurrent weights with gain sweep `g`
- Gaussian white-noise input drive
- Snapshot-wise resolvent analysis on an operator of your choice:
  - `B_t = diag(u_t) W_hh^T` (default; directly from the BPTT adjoint factor)
  - `A_t = diag(u_t) W_hh^T diag(alpha)` (optional)

It produces curves for:
- Max Lyapunov exponent (finite-time, Benettin QR)
- Critical slowing down proxies (energy autocorrelation + AR(1) `alpha`)
- Spectral radius and gap (chosen operator)
- Rank-1 dominance of the susceptibility (via SVD of the resolvent)
- Diagonal dominance of the susceptibility (diag energy ratio)
- Scalarization error vs Lyapunov for multiple probe source types

## Run

From repo root:

```bash
python Compare_RNN/analysis/oll_stage0_probe/stage0_probe.py --operator B
```

Recommended (finer gain scan):

```bash
python Compare_RNN/analysis/oll_stage0_probe/stage0_probe.py \
  --hidden 256 \
  --input-size 8 \
  --batch 16 \
  --burn 400 \
  --probe 2000 \
  --gains "0.5,0.6,0.7,0.8,0.9,1.0,1.1,1.2,1.3,1.4,1.5" \
  --operator B
```

## Output

Creates `plots/oll_stage0_probe_<timestamp>/`:
- `summary.json`
- `lyapunov_vs_g.png`
- `alpha_vs_g.png`, `energy_r1_vs_g.png`, `energy_tau_vs_g.png`
- `rhoA_vs_g.png`, `gap_ratio_vs_g.png`, `rank1_evr_vs_g.png`, `diag_power_ratio_vs_g.png`
- `relerr_vs_lyap__*.png` and `cos_vs_lyap__*.png` for each probe type.

Optional (direct BPTT-vs-OLL check on a synthetic label-free loss):
```bash
python Compare_RNN/analysis/oll_stage0_probe/stage0_probe.py --operator B --bptt-loss state_energy
```
