Metadata-Version: 2.4
Name: fawp-index
Version: 2.2.1
Summary: FAWP Alpha Index — Information-Control Exclusion Principle detector
Author: Ralph Clayton
License-Expression: MIT
Project-URL: Homepage, https://github.com/DrRalphClayton/fawp-index
Project-URL: Repository, https://github.com/DrRalphClayton/fawp-index
Project-URL: Documentation, https://github.com/DrRalphClayton/fawp-index/tree/main/docs
Project-URL: Demo, https://fawp-scanner.info
Project-URL: PyPI, https://pypi.org/project/fawp-index/
Project-URL: Issues, https://github.com/DrRalphClayton/fawp-index/issues
Project-URL: Changelog, https://github.com/DrRalphClayton/fawp-index/blob/main/CHANGELOG.md
Project-URL: Paper (E1-E7), https://doi.org/10.5281/zenodo.18663547
Project-URL: Paper (E8), https://doi.org/10.5281/zenodo.18673949
Project-URL: Zenodo Software, https://doi.org/10.5281/zenodo.18673949
Project-URL: Figshare, https://doi.org/10.6084/m9.figshare.31799104
Project-URL: OSF Project, https://osf.io/hzwgp/
Project-URL: Book, https://www.amazon.com/dp/B0GS1ZVNM7/
Keywords: fawp,fawp-index,agency-horizon,volumetric-time-model,information-control-exclusion,operational-accessibility,mutual-information,forecasting,information-theory,control-theory,time-series,finance,weather,climate,regime-detection,early-warning,sphere
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Science/Research
Classifier: Intended Audience :: Financial and Insurance Industry
Classifier: Intended Audience :: Developers
Classifier: Topic :: Scientific/Engineering
Classifier: Topic :: Scientific/Engineering :: Information Analysis
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Classifier: Topic :: Office/Business :: Financial
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Operating System :: OS Independent
Classifier: Natural Language :: English
Requires-Python: >=3.9
Description-Content-Type: text/markdown
License-File: LICENSE.txt
Requires-Dist: numpy>=1.21
Requires-Dist: pandas>=1.3
Provides-Extra: plot
Requires-Dist: matplotlib>=3.4; extra == "plot"
Provides-Extra: plotly
Requires-Dist: plotly>=5.0; extra == "plotly"
Provides-Extra: fast
Requires-Dist: numba>=0.57; extra == "fast"
Provides-Extra: report
Requires-Dist: reportlab>=4.0; extra == "report"
Requires-Dist: matplotlib>=3.4; extra == "report"
Provides-Extra: finance
Requires-Dist: yfinance>=0.2; extra == "finance"
Provides-Extra: weather
Requires-Dist: requests>=2.28; extra == "weather"
Requires-Dist: openmeteo-requests>=0.3; extra == "weather"
Requires-Dist: requests-cache>=1.0; extra == "weather"
Requires-Dist: retry-requests>=1.0; extra == "weather"
Requires-Dist: xarray>=2023.1; extra == "weather"
Requires-Dist: netcdf4>=1.6; extra == "weather"
Provides-Extra: sklearn
Requires-Dist: scikit-learn>=1.0; extra == "sklearn"
Provides-Extra: dashboard
Requires-Dist: streamlit>=1.30; extra == "dashboard"
Requires-Dist: matplotlib>=3.4; extra == "dashboard"
Requires-Dist: yfinance>=0.2; extra == "dashboard"
Requires-Dist: supabase>=2.0; extra == "dashboard"
Requires-Dist: openmeteo-requests>=0.3; extra == "dashboard"
Requires-Dist: requests-cache>=1.0; extra == "dashboard"
Requires-Dist: retry-requests>=1.0; extra == "dashboard"
Provides-Extra: test
Requires-Dist: pytest>=7.0; extra == "test"
Requires-Dist: pytest-cov>=4.0; extra == "test"
Requires-Dist: matplotlib>=3.4; extra == "test"
Requires-Dist: reportlab>=4.0; extra == "test"
Provides-Extra: dev
Requires-Dist: pytest>=7.0; extra == "dev"
Requires-Dist: pytest-cov>=4.0; extra == "dev"
Requires-Dist: matplotlib>=3.4; extra == "dev"
Requires-Dist: reportlab>=4.0; extra == "dev"
Requires-Dist: scikit-learn>=1.0; extra == "dev"
Requires-Dist: twine>=4.0; extra == "dev"
Requires-Dist: build>=0.10; extra == "dev"
Requires-Dist: ruff>=0.1; extra == "dev"
Requires-Dist: mkdocs>=1.5; extra == "dev"
Requires-Dist: mkdocs-material>=9.0; extra == "dev"
Provides-Extra: all
Requires-Dist: matplotlib>=3.4; extra == "all"
Requires-Dist: reportlab>=4.0; extra == "all"
Requires-Dist: yfinance>=0.2; extra == "all"
Requires-Dist: requests>=2.28; extra == "all"
Requires-Dist: scikit-learn>=1.0; extra == "all"
Requires-Dist: plotly>=5.0; extra == "all"
Requires-Dist: numba>=0.57; extra == "all"
Dynamic: license-file

# fawp-index

[![PyPI version](https://img.shields.io/pypi/v/fawp-index.svg)](https://pypi.org/project/fawp-index/)
[![PyPI downloads](https://img.shields.io/pypi/dm/fawp-index.svg)](https://pypi.org/project/fawp-index/)
[![Python](https://img.shields.io/pypi/pyversions/fawp-index)](https://pypi.org/project/fawp-index/)
[![CI](https://github.com/DrRalphClayton/fawp-index/actions/workflows/ci.yml/badge.svg)](https://github.com/DrRalphClayton/fawp-index/actions/workflows/ci.yml)
[![License: MIT](https://img.shields.io/badge/license-MIT-blue.svg)](LICENSE.txt)
[![DOI](https://img.shields.io/badge/DOI-10.5281%2Fzenodo.18673949-blue)](https://doi.org/10.5281/zenodo.18673949)
[![Demo](https://img.shields.io/badge/🔴%20Live%20Demo-fawp--scanner.info-gold)](https://fawp-scanner.info)
[![Docs](https://img.shields.io/badge/docs-fawp--index-blue?logo=readthedocs)](https://drralphclayton.github.io/fawp-index/)
[![Figshare](https://img.shields.io/badge/data-Figshare-blue)](https://doi.org/10.6084/m9.figshare.31799104)
[![OSF](https://img.shields.io/badge/project-OSF-teal)](https://osf.io/hzwgp/)
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/DrRalphClayton/fawp-index/main?filepath=notebooks/E9_full_replication.ipynb)

---

## Screenshots

### Finance Scanner
![FAWP Finance Scanner — SPY FAWP detection](https://raw.githubusercontent.com/DrRalphClayton/fawp-index/main/docs/images/scanner_result.png)

### Weather Scanner
![FAWP Weather Scanner — London temperature](https://raw.githubusercontent.com/DrRalphClayton/fawp-index/main/docs/images/weather_result.png)

### Seismic Scanner
![FAWP Seismic Scanner — California earthquake catalog](https://raw.githubusercontent.com/DrRalphClayton/fawp-index/main/docs/images/seismic_result.png)



<div align="center">

### 🔴 Try it live — no install needed

**[→ fawp-scanner.info](https://fawp-scanner.info)**

Scan any stock, ETF, or crypto in your browser.
Enter tickers → Fetch data → See regime detection in real time.

*Powered by fawp-index v2.2.1 · [pip install it](#install) for full local control*

</div>

---

## Your model still predicts. But you've already lost control.

**fawp-index** detects the moment a system crosses into the
*Information-Control Exclusion Principle* regime — where **predictive
information persists** but **the ability to act on it has collapsed**.

| Domain | What predicts | What collapses |
|--------|--------------|----------------|
| 📈 Quant finance | Factor alpha signal | Market execution edge (crowding) |
| 🌀 Dynamical systems | State forecasts | Stabilising control authority |
| 🌊 Weather / climate | Forecast skill | Intervention window |
| 🌍 Seismic | Precursor signal | Stress release control |
| 🤖 ML systems | Model predictions | Ability to retrain / intervene |


---

## What it looks like

<!-- Add dashboard screenshot here: docs/images/scanner_tab.png -->
<!-- To generate: sign in → run scan on SPY QQQ GLD BTC → screenshot Scanner tab -->

**Scanner tab** — severity pills, sparklines, confidence badges, ODW bars

Each asset row shows:
- **Severity pill** — FAWP 🔴 / HIGH / WATCH / CLEAR
- **Score** — regime score (0–1) colour-coded by tier  
- **Sparkline** — 6-window score trend with ▲/▼ arrow
- **Confidence badge** — HIGH / MED / LOW based on persistence + ODW concentration
- **Gap (bits)** — leverage gap magnitude
- **ODW bar** — proportional bar showing detection window within τ range

Click any flagged asset → **"Why flagged?"** expander with full attribution.

**Compare tab** — FAWP vs RSI, realised vol, momentum, MA slope

Forward-return lift at 1 / 5 / 20 bars when each signal is in extreme zone.
FAWP row highlighted in gold. Export to CSV.

**Validation tab** — forward-return statistics after signal fires

Hit rate · mean return · MAE · MFE · p5/p95 · FAWP vs baseline comparison.

**History tab** — score timeline per asset across all saved scans

---

## Live demo

**[fawp-scanner.info](https://fawp-scanner.info)** — interactive dashboard running on live data.
No install required. Scan equities, crypto, and sectors in your browser.

---

## The Science Behind FAWP

<details>
<summary><b>📐 Click to expand — theory, calibration constants & papers</b></summary>

### Information-Control Exclusion Principle (ICEP)

FAWP detects the moment a system crosses into a regime where **predictive information persists but operational control collapses** — the *Information-Control Exclusion Principle* (ICEP), formalised in the Volumetric Time Model.

The detection pipeline:

```
Prediction MI  I(X_t; X_{t+τ})  →  peaks inside the Optimal Decision Window (ODW)
Steering MI    I(X_t; ΔX_{t+τ}) →  collapses toward ε (the "cliff")
Gap            α(τ) = I_pred − I_steer  →  sustained positive gap = FAWP detected
```

### Calibration constants (SPHERE-16, E9.7 sweep)

| Constant | Value | Source |
|---|---|---|
| `PEAK_PRED_BITS` | 2.233669 bits | SPHERE-16 Eq. 4 |
| `ETA_PRED_CORRECTED` | 0.0 (strict post-null floor) | SPHERE-16 Eq. 8 |
| `PRED_AT_CLIFF` | 1.01 bits | SPHERE-16 Eq. 5 |
| `NULL_MAX_SHUFFLE` | 0.00216 bits | SPHERE-16 Eq. 19 |
| `NULL_MAX_SHIFT` | 0.00421 bits | SPHERE-16 Eq. 19 |
| `E97_MEAN_LEAD_GAP2` | +0.61 delays avg | E9.7 4244-run sweep |

### Papers (SPHERE series)

| Paper | DOI | What it establishes |
|---|---|---|
| E1–E7 (Volumetric Time Model) | [10.5281/zenodo.18663547](https://doi.org/10.5281/zenodo.18663547) | ICEP theory, ODW, agency horizon |
| E8 / SPHERE-16 (flagship) | [10.5281/zenodo.18673949](https://doi.org/10.5281/zenodo.18673949) | Peak pred = 2.233669 bits, null controls |
| E9 suite | [10.5281/zenodo.19065421](https://doi.org/10.5281/zenodo.19065421) | Comparative timing, gap2 detector, robustness |
| Figshare data | [10.6084/m9.figshare.31799104](https://doi.org/10.6084/m9.figshare.31799104) | Research data, supplementary materials |
| OSF project | [osf.io/hzwgp](https://osf.io/hzwgp/overview) | Preprints, data, notebooks |

Access calibration constants directly:
```python
import fawp_index as fi
print(fi.PEAK_PRED_BITS)                    # 2.233669
print(fi.E97_MEAN_LEAD_GAP2_TO_CLIFF_U)    # 0.7552
print(fi.TAU_H_PLUS_E8)                     # 4
```

</details>

## Install

```bash
pip install fawp-index                   # core
pip install "fawp-index[plot]"           # + matplotlib figures
pip install "fawp-index[dashboard]"      # + Streamlit dashboard
pip install "fawp-index[fast]"           # + Numba JIT (5–15× faster null scans)
pip install "fawp-index[all]"            # everything
```

---

## One-command demo

```bash
pip install "fawp-index[dashboard]"
fawp-demo                          # opens browser with synthetic data instantly
fawp-demo --asset BTC-USD SPY QQQ  # real tickers via yfinance
```

No CSV. No API key. No config. Just install and run.

---

## 60-second quickstart

```python
import numpy as np
from fawp_index import FAWPAlphaIndex

# Simulate: strong prediction, collapsed steering = FAWP
pred   = np.random.randn(5000)
future = pred[20:] + np.random.randn(4980) * 0.3   # forecastable
action = np.random.randn(4980) * 0.001              # near-zero = no steering
obs    = np.random.randn(4980) * 0.1

result = FAWPAlphaIndex().compute(pred[:4980], future, action, obs)
print(result.summary())
result.plot()   # pip install "fawp-index[plot]"
```

Output:
```
==================================================
FAWP Alpha Index v2.1 — Results Summary
==================================================
Agency Horizon (tau_h):  1
Peak Alpha Index:        0.2847
Peak Alpha at tau:       3
FAWP regime detected:   YES
FAWP tau range:          [1, 2, 3, 4, 5]
==================================================
```

---

## Run the benchmarks (zero data needed)

The fastest way to see it work:

```bash
pip install "fawp-index[plot]"
python -c "
from fawp_index import run_benchmarks
suite = run_benchmarks()
print(suite.summary())
suite.verify_all()
"
```

```
Case                  Expected   Detected   Result
----------------------------------------------------
clean_control         FAWP       FAWP       ✅ PASS
prediction_only       none       none       ✅ PASS
control_only          none       none       ✅ PASS
noisy_false_positive  none       none       ✅ PASS
delayed_collapse      FAWP       FAWP       ✅ PASS
All 5 assertions passed.
```

---

## Market scanner

```python
import pandas as pd
from fawp_index.market import scan_fawp_market

df   = pd.read_csv("SPY.csv", parse_dates=["Date"], index_col="Date")
scan = scan_fawp_market(df, ticker="SPY", close_col="Close", volume_col="Volume")

print(scan.summary())
scan.plot(prices=df["Close"])
scan.to_html("spy_fawp.html")
```

**Financial interpretation:**
- **pred channel** `I(returnₜ ; returnₜ₊Δ)` — is the market still forecastable?
- **steer channel** `I(signed_flowₜ ; returnₜ₊τ)` — do your orders still move price?
- **FAWP window** — you can forecast direction, but your orders no longer move price

---

## Watchlist scanner

```python
from fawp_index.watchlist import scan_watchlist

# Fetch and scan automatically via yfinance:
result = scan_watchlist(
    ["SPY", "QQQ", "GLD", "BTC-USD", "ETH-USD"],
    period     = "2y",
    timeframes = ["1d", "1wk"],
)

result.rank_by("score")        # strongest current regime score
result.rank_by("gap")          # widest leverage gap (bits)
result.rank_by("persistence")  # longest active regime
result.active_regimes()        # only currently flagged assets
result.top_n(5, "score")

result.to_html("watchlist.html")
```

---

## Saved watchlists

```bash
# Create and persist named watchlists
fawp-watchlist create tech AAPL MSFT NVDA AMD
fawp-watchlist create crypto BTC-USD ETH-USD SOL-USD --period 1y
fawp-watchlist scan tech --leaderboard --explain --out tech.html
fawp-watchlist list
fawp-watchlist show tech
```

---

## Leaderboard

```python
from fawp_index.leaderboard import Leaderboard

result = scan_watchlist(["SPY", "QQQ", "GLD", "BTC-USD"], period="2y")
lb = Leaderboard.from_watchlist(result)

print(lb.summary())
lb.to_html("leaderboard.html")
```

Four ranked categories: **Top FAWP** · **Rising Risk** · **Collapsing Control** · **Strongest ODW**

---

## Explain score

```python
from fawp_index.explain import explain_asset

result = scan_watchlist(["SPY", "QQQ"], period="2y")
top = result.rank_by("score")[0]
print(explain_asset(top))
```

```
============================================================
  SPY  [1d]
============================================================
  FAWP Score   : 81/100
  Status       : 🔴 HIGH  —  FAWP ACTIVE  (12 days)
------------------------------------------------------------
  Prediction   : elevated (0.142 bits)
  Steering     : collapsed (0.0001 bits ≈ zero)
  Leverage gap : large (0.141 bits)
  ODW          : detected (τ = 1–12)
------------------------------------------------------------
  Why flagged:
    • FAWP active 12 days — score rising 3 consecutive windows
    • Steering MI below ε at 11 of 12 tau values
    • Leverage gap 0.141 bits
    • ODW spans 12 tau steps (τ 1–12)
------------------------------------------------------------
  Recommendation:
  Prediction persists but execution edge has collapsed.
  Reduce size or investigate crowding / latency conditions.
============================================================
```

---

## Alerts

```python
from fawp_index.alerts import AlertEngine, AlertSeverity

engine = AlertEngine(
    gap_threshold=0.05,
    cooldown_hours=4,                        # suppress repeats within 4h
    min_consecutive_windows=2,               # only fire after 2 flagged windows
    score_change_threshold=0.02,             # only if score changed ≥ 0.02
    min_severity=AlertSeverity.MEDIUM,       # ignore LOW signals
    state_path="fawp_state.json",
)
engine.add_terminal()
engine.add_telegram(token="BOT_TOKEN", chat_id="CHAT_ID")
engine.add_discord(webhook_url="https://discord.com/api/webhooks/...")
engine.add_email(smtp_host="smtp.gmail.com", username="you@gmail.com",
                 password="app_password", to_addrs=["you@gmail.com"])
engine.add_webhook("https://hooks.slack.com/services/...")

result = scan_watchlist(dfs)
alerts = engine.check(result)
engine.daily_summary(result)
```

---

## Significance testing

```python
from fawp_index import ODWDetector, fawp_significance

odw = ODWDetector.from_e9_2_data()
sig = fawp_significance(odw, n_bootstrap=200)

print(sig.summary())
# p_fawp=1.000  p_null=0.145  significant=YES
# ci_tau_h=[31,31]  ci_peak_gap=[1.538, 1.562] bits
```

---

## Benchmark suite

```python
from fawp_index import run_benchmarks

suite = run_benchmarks()
suite.verify_all()
suite.to_html("benchmarks.html")
```

| Case | Expected | Description |
|------|:--------:|-------------|
| `clean_control` | ✅ FAWP | Textbook: steering collapses, prediction survives |
| `prediction_only` | ❌ None | Predictable system, no steering channel |
| `control_only` | ❌ None | Active controller, no predictive horizon |
| `noisy_false_positive` | ❌ None | Noisy stable — designed to trap detectors |
| `delayed_collapse` | ✅ FAWP | Fast-collapsing unstable system, narrow ODW |

---

## Dashboard

```bash
pip install "fawp-index[dashboard]"
fawp-dashboard                     # opens on http://localhost:8501

# Or from repo:
cd dashboard && streamlit run app.py
```

**Dashboard features (v2.2.1):**
- Severity pills (FAWP / HIGH / WATCH / CLEAR) with pulsing indicators
- Sparkline score trend per asset with ▲/▼ arrows
- ODW proportional bar showing window position in τ range
- Filter bar (All / FAWP only / Watching / Rising)
- Inline "Why flagged?" explain cards
- Mini leaderboard (Top FAWP · Rising Risk · Collapsing Control · Strongest ODW)
- Scan metadata: timestamp, duration, ε, window, τmax

---

## CLI

```bash
# Detect FAWP in a CSV:
fawp-index detect   data.csv --state price --action trade_size --plot

# Rolling market scan:
fawp-index market   SPY.csv --close Close --volume Volume --out report.html

# Scan a watchlist:
fawp-index watchlist spy.csv qqq.csv gld.csv --labels SPY QQQ GLD --out wl.html

# Scan with leaderboard + explain:
fawp-scan --preset equities --leaderboard --explain

# Saved watchlists:
fawp-watchlist create tech AAPL MSFT NVDA AMD
fawp-watchlist scan tech --rank-by gap --out tech.html

# Significance test:
fawp-index significance data.csv --state price --action trade

# Benchmark suite:
fawp-index benchmarks --verify

# Version:
fawp-index version
```

---

## DataFrame API

```python
from fawp_index import fawp_from_dataframe, fawp_rolling

# Single detection:
result = fawp_from_dataframe(df, pred_col="factor", action_col="trade", future_col="fwd_return")

# Rolling — adds fawp_pred_mi, fawp_steer_mi, fawp_gap, fawp_in_regime columns:
df_annotated = fawp_rolling(df, pred_col="returns", action_col="volume")
df_annotated[df_annotated["fawp_in_regime"]]
```

---

## Calibration constants

All calibration anchors are in `fawp_index.constants`, derived directly from the published papers:

```python
from fawp_index.constants import (
    EPSILON_STEERING_RAW,      # 0.01 bits — raw steering threshold (E8/E9 standard)
    EPSILON_STEERING_CORRECTED,# 1e-4 bits — post-null-correction threshold
    BETA_NULL_QUANTILE,        # 0.99 — conservative null floor quantile
    PERSISTENCE_WINDOW_M,      # 5 — Sm(τ) window width
    PERSISTENCE_RULE_M,        # 3 — m-of-n gate (E9.1 confirmed)
    PERSISTENCE_RULE_N,        # 4
    FLAGSHIP_A,                # 1.02 — E8/E9 canonical unstable regime
    FLAGSHIP_K,                # 0.8
    TAU_PLUS_H_E9,             # 31 — E9.2 agency horizon
    TAU_F_E9,                  # 36 — E9.2 functional cliff
    PEAK_GAP_BITS_E9_U,        # 1.5489 bits — E9.2 peak leverage gap (u-channel)
    PEAK_GAP_BITS_E9_XI,       # 1.5524 bits — E9.2 peak leverage gap (ξ-channel)
)
```

---

## Citation

```bibtex
@software{clayton2026fawpindex,
  author  = {Ralph Clayton},
  title   = {fawp-index: Information-Control Exclusion Principle detector},
  year    = {2026},
  version = {2.2.1},
  url     = {https://github.com/DrRalphClayton/fawp-index},
  doi     = {10.5281/zenodo.18673949}
}

@article{clayton2026agency,
  author = {Ralph Clayton},
  title  = {Forecasting Without Power: Agency Horizons and the Leverage Gap},
  year   = {2026},
  doi    = {10.5281/zenodo.18663547}
}
```

---

## Links

- 🌐 **Live demo:** [fawp-scanner.info](https://fawp-scanner.info)
- 📦 **PyPI:** [pypi.org/project/fawp-index](https://pypi.org/project/fawp-index/)
- 📂 **GitHub:** [github.com/DrRalphClayton/fawp-index](https://github.com/DrRalphClayton/fawp-index)
- 📄 **Paper (E1–E7):** [doi:10.5281/zenodo.18663547](https://doi.org/10.5281/zenodo.18663547)
- 📄 **Paper (E8):** [doi:10.5281/zenodo.18673949](https://doi.org/10.5281/zenodo.18673949)
- 📄 **Paper (E9 suite):** [doi:10.5281/zenodo.19065421](https://doi.org/10.5281/zenodo.19065421)
- 🗂️ **Figshare:** [doi:10.6084/m9.figshare.31799104](https://doi.org/10.6084/m9.figshare.31799104)
- 🔬 **OSF Project:** [osf.io/hzwgp](https://osf.io/hzwgp/overview)
- 📗 **Book:** [*Forecasting Without Power*](https://www.amazon.com/dp/B0GS1ZVNM7/) — Ralph Clayton (2026)
- 📊 **Docs:** [`docs/`](docs/) — quickstart, examples, market, watchlist, alerts, significance, benchmarks, dashboard

---

## Module docs

| File | Contents |
|------|---------|
| [`docs/quickstart.md`](docs/quickstart.md) | Getting started guide |
| [`docs/examples.md`](docs/examples.md) | Example gallery — common use cases |
| [`docs/market.md`](docs/market.md) | Market scanner API |
| [`docs/watchlist.md`](docs/watchlist.md) | Watchlist scanner + ranking |
| [`docs/alerts.md`](docs/alerts.md) | Alert engine + channel setup |
| [`docs/significance.md`](docs/significance.md) | Significance testing |
| [`docs/benchmarks.md`](docs/benchmarks.md) | Benchmark cases + verification |
| [`docs/dashboard.md`](docs/dashboard.md) | Dashboard install + deploy |

---

*MIT License · Ralph Clayton · 2026*
