voidly
Multi-horizon shutdown forecast

BE — three honest horizons

How the current-regime shutdown-risk level for BE reads over 1 day, 7 days, and 30 days. Each horizon uses its own XGBoost model with per-horizon SHAP attribution and a 90% conformal interval. These are current-regime risk signals, not onset predictions — see the scope note below.

Generated 2026-05-23 18:03 UTC · model multi-horizon-h-v1 · raw JSON

Probabilities

1 day
1d
27.1%
90% interval [17%, 37%]
7 days
7d
35.6%
90% interval [17%, 54%]
30 days
30d
70.0%
90% interval [20%, 100%]

Consistency check

OK — monotonicP(1d) ≤ P(7d) ≤ P(30d)

The three horizons are internally consistent: longer windows capture at least the risk of shorter windows. This is the expected behavior — a 30-day window must contain any 7-day or 1-day shutdown.

27.1% ≤ 35.6% ≤ 70.0%

Top-5 SHAP features per horizon

Each horizon has its own learned drivers. Positive SHAP values push the prediction up; negative values push it down. Features differ across horizons because near-term risk responds to acute signals, while month-out risk responds to slower structural factors.

HorizonRankFeatureSHAP
1-day#1week_of_year-0.783
#2risk_tier-0.410
#3day_of_week-0.117
#4recent_shutdown-0.085
#5gdelt_unrest_30d-0.043
7-day#1risk_tier-0.728
#2week_of_year-0.664
#3month-0.106
#4recent_shutdown-0.069
#5gdelt_unrest_30d-0.055
30-day#1week_of_year-1.003
#2risk_tier-0.650
#3recent_shutdown-0.078
#4month-0.061
#5gdelt_unrest_30d-0.060

Honest caveats

  • Each horizon is a separate XGBoost model with its own features and its own honest evaluation. LOCO AUC across spotlight countries: 1d 0.91 · 7d 0.88 · 30d 0.84.
  • 30-day forecasts inherently have wider conformal intervals (more time = more uncertainty). A wide interval is not a bug — it's honesty.
  • These numbers are not guarantees. A 70% probability does not mean a shutdown is certain; a 20% probability does not mean you're safe.
  • See /atlas/multi-horizon for the cross-country index, or /atlas/models for the full model registry.

Related