Sortino ratio
Query
sortino = (E[r] · 365 − 0.01) / (σ_neg · √365)WITH
'2024-01-01' AS start_date,
'2024-12-31' AS end_date,
365 AS sessions_per_year,
0.01 AS risk_free_rate,
candles AS (
SELECT toDate(start) AS day, market, toFloat64(close) AS close
FROM api.ohlcv(candle_duration_in_minutes = 1440)
WHERE exchange = 'binance'
AND market IN ('BTC-USDT', 'ETH-USDT', 'SOL-USDT', 'ADA-USDT', 'DOGE-USDT')
AND start BETWEEN start_date AND end_date
),
market_returns AS (
SELECT day, market,
close / lagInFrame(toNullable(close), 1) OVER (PARTITION BY market ORDER BY day) - 1 AS ret
FROM candles
),
all_returns AS (
SELECT day, market, ret FROM market_returns WHERE ret IS NOT NULL
UNION ALL
SELECT day, 'PORTFOLIO' AS market, avg(ret) AS portfolio_ret
FROM market_returns WHERE ret IS NOT NULL GROUP BY day
)
SELECT market,
(avg(ret) * sessions_per_year - risk_free_rate)
/ (stddevSamp(if(ret < 0, ret, NULL)) * sqrt(sessions_per_year)) AS sortino
FROM all_returns
GROUP BY market
ORDER BY marketOutput (2024)
market
sortino
Last updated