skills/volatility-modeling/SKILL.md
Volatility estimation, forecasting, and regime classification using GARCH, EWMA, realized volatility, and volatility cones
npx skillsauth add agiprolabs/claude-trading-skills volatility-modelingInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Volatility — the magnitude of price fluctuations — is arguably the single most important quantity in trading. It drives position sizing, stop placement, option pricing, and regime detection. This skill covers estimation, forecasting, and practical application of volatility in crypto markets.
| Use Case | How Volatility Is Used | |---|---| | Position sizing | Scale position inversely with vol so each trade risks a consistent dollar amount | | Stop placement | ATR-based stops widen in high-vol regimes, tighten in low-vol | | Strategy selection | Mean-reversion works in low vol; momentum works in high vol | | Risk budgeting | Vol-target portfolios maintain constant portfolio-level risk | | Regime detection | Vol regime shifts signal changing market dynamics | | Option pricing | Implied vs realized vol gap creates trading opportunities |
Computed from observed past returns. The most common and directly measurable form. Multiple estimators exist with different statistical efficiency.
Derived from option prices via Black-Scholes or similar models. Limited in crypto DeFi where liquid options markets are sparse, but available on Deribit for BTC/ETH.
Predicted future volatility from models like EWMA or GARCH. Used for forward-looking position sizing and risk budgets.
The simplest estimator. Compute the standard deviation of log returns and annualize.
import numpy as np
log_returns = np.log(closes[1:] / closes[:-1])
vol_daily = np.std(log_returns, ddof=1)
vol_annual = vol_daily * np.sqrt(365) # crypto trades 365 days
Uses the daily high-low range, which is ~5x more statistically efficient than close-to-close.
hl_ratio = np.log(highs / lows)
vol_parkinson = np.sqrt(np.mean(hl_ratio**2) / (4 * np.log(2))) * np.sqrt(365)
The most efficient single-day OHLC estimator.
hl = np.log(highs / lows)
co = np.log(closes / opens)
gk = np.mean(0.5 * hl**2 - (2 * np.log(2) - 1) * co**2)
vol_gk = np.sqrt(gk) * np.sqrt(365)
Combines overnight (close-to-open) and open-to-close components. Handles gaps properly. Less relevant for 24/7 crypto but useful for tokens with sporadic trading.
RiskMetrics approach — no parameters to estimate beyond λ.
lam = 0.94 # RiskMetrics default for daily
ewma_var = np.zeros(len(returns))
ewma_var[0] = returns[0] ** 2
for t in range(1, len(returns)):
ewma_var[t] = lam * ewma_var[t - 1] + (1 - lam) * returns[t - 1] ** 2
vol_ewma = np.sqrt(ewma_var) * np.sqrt(365)
The workhorse autoregressive volatility model. Captures volatility clustering.
σ²_t = ω + α · r²_{t-1} + β · σ²_{t-1}
Estimated via maximum likelihood. See references/estimators.md for details.
Volatility cones show the percentile distribution of realized volatility at different lookback windows, revealing whether current vol is historically high or low.
See references/volatility_cones.md for full methodology and worked examples.
Crypto vol differs from traditional assets in important ways:
| Characteristic | Detail | |---|---| | Level | 50–150% annualized is typical; TradFi equities are 15–25% | | Clustering | Strong — high-vol days cluster together | | Weekday patterns | Weekend vol often lower but weekend gaps can be large | | Volume correlation | Vol and volume are positively correlated | | Regime dependence | Bull market vol ≠ bear market vol; ranges are different | | Mean reversion | Vol mean-reverts more reliably than price | | Tail risk | Fat tails — more extreme moves than normal distribution predicts |
| Regime | Annualized Vol Range | Characteristics | |---|---|---| | Low vol | < 40% | Range-bound, mean reversion works | | Normal vol | 40–80% | Trending possible, balanced strategies | | High vol | 80–120% | Strong trends or sharp reversals | | Crisis vol | > 120% | Liquidation cascades, reduced position size |
Simple and effective. The current EWMA variance estimate is the 1-step forecast. Multi-step forecasts are flat (same as 1-step).
GARCH produces a term structure of variance forecasts:
σ²_{t+h} = V_L + (α + β)^h · (σ²_t − V_L)
Where V_L = ω / (1 − α − β) is the long-run variance.
See scripts/vol_forecast.py for a working implementation.
# Vol-target position sizing
target_vol = 0.02 # 2% daily portfolio vol target
current_vol = 0.05 # 5% daily asset vol (annualized ~95%)
weight = target_vol / current_vol # = 0.40 → 40% allocation
See the position-sizing skill for complete integration.
atr_14 = talib.ATR(highs, lows, closes, timeperiod=14)
stop_distance = 2.0 * atr_14[-1] # 2x ATR stop
stop_price = entry_price - stop_distance # for longs
vol_percentile = current_vol_percentile(token, window=30)
if vol_percentile < 25:
strategy = "mean_reversion"
elif vol_percentile > 75:
strategy = "momentum_breakout"
else:
strategy = "balanced"
| File | Description |
|---|---|
| references/estimators.md | Full derivations and details for all volatility estimators |
| references/volatility_cones.md | Cone construction methodology and interpretation guide |
| File | Description |
|---|---|
| scripts/estimate_volatility.py | Multi-estimator volatility computation with cone analysis |
| scripts/vol_forecast.py | EWMA and GARCH forecasting with term structure output |
regime-detection — Classify market regimes using volatility as a key input.position-sizing — Scale positions inversely with volatility.risk-management — Portfolio-level vol targeting and risk budgets.pandas-ta — ATR and Bollinger Bands are volatility-based indicators.custom-indicators — Build crypto-specific volatility indicators.uv pip install pandas numpy scipy
Optional for live data:
uv pip install httpx
data-ai
DeFi yield evaluation including fee APR, real vs nominal yield, net APY after costs, and yield sustainability analysis
tools
Real-time Solana transaction and account streaming via Yellowstone gRPC (Geyser plugin)
tools
Large wallet monitoring, accumulation and distribution detection, and smart money signal generation for Solana tokens
tools
Wash sale detection under 2025 US crypto rules with 61-day window monitoring, disallowed loss tracking, and safe re-entry countdown