Python

accumulate : equity curve et drawdown maximal

Cumuls avec itertools.accumulate : somme courante pour la courbe de capital, max courant pour les plus hauts, et drawdown par différence.

Cas d'usage

Calculer le max drawdown d'une série de P&L journaliers sans pandas ni numpy.

Prérequis

Python 3.9+

Python
from itertools import accumulate

pnl_journalier = [120.5, -80.0, 45.2, -210.0, 95.0]

# Equity curve : cumul des P&L à partir du capital initial
equity = list(accumulate(pnl_journalier, initial=10_000))

# Plus haut historique (running max) pour calculer le drawdown
peaks = list(accumulate(equity, max))
drawdowns = [e - p for e, p in zip(equity, peaks)]

max_dd = min(drawdowns)
print(f"Max drawdown : {max_dd:.2f}")

Résultat

>>> equity
[10000, 10120.5, 10040.5, 10085.7, 9875.7, 9970.7]
>>> [round(d, 2) for d in drawdowns]
[0, 0.0, -80.0, -34.8, -244.8, -149.8]

Max drawdown : -244.80
itertoolsaccumulateFinanceDrawdown

Snippets liés

Retour au Data Lab