Ich interessiere mich für die Verteilung des maximalen Drawdowns eines zufälligen Spaziergangs: Sei wobei . Der maximale Drawdown nach Perioden beträgt . Ein Artikel von Magdon-Ismail et. al. gibt die Verteilung für die maximale Absenkung einer Brownschen Bewegung mit Drift an. Der Ausdruck beinhaltet eine unendliche Summe, die einige Begriffe enthält, die nur implizit definiert sind. Ich habe Probleme beim Schreiben einer konvergierenden Implementierung. Ist jemandem ein alternativer Ausdruck der CDF oder eine Referenzimplementierung im Code bekannt?
distributions
cdf
finance
random-walk
shabbychef
quelle
quelle
Antworten:
Dies ist eine alternierende Summe. Jedes aufeinanderfolgende Paar bricht fast ab; solche Paarsummen nehmen schließlich monoton ab.
Ein Ansatz besteht also darin, die Summe paarweise zu berechnen, wobei = {1,2}, {3,4}, {5,6} usw. (Dadurch werden auch viele Gleitkommafehler vermieden.) Einige Weitere Tricks können helfen:n
(1) Zur Lösung für einen positive Konstante , ein guter Ausgangswert zu suchen , - und eine ausgezeichnete Näherung für den größte root-- ist . Ich vermute, Newton-Raphson sollte wirklich gut funktionieren.tan(t)=t/α α nth t=(n+1/2)π−α(n+1/2)π
(2) Nach einer kleinen Anzahl von Anfangstermen nehmen die Summen der Paare sehr, sehr gleichmäßig ab. Die Logarithmen der Absolutwerte exponentiell beabstandeter Paare nehmen schnell nahezu linear ab. Dies bedeutet, dass Sie zwischen einer sehr kleinen Anzahl berechneter Paarsummen interpolieren können, um alle nicht berechneten Paarsummen zu schätzen. Zum Beispiel durch Berechnen der Werte für nur Paare (2,3), (4,5), (8,9), (16,17), ..., (16384, 16385) und Konstruieren des Interpolationspolynoms für diese (gedacht als die Werte einer Funktion bei 1, 2, ..., 14) und unter Verwendung der Argumenteh=μ=σ=1 Für die Worst-Case-Fehler konnte ich eine sechsstellige Genauigkeit erreichen. (Noch schöner ist, dass die Fehler im Vorzeichen schwingen, was darauf hindeutet, dass die Genauigkeit der summierten interpolierten Werte möglicherweise etwas besser als sechsstellig ist.) Sie könnten die Grenzsumme wahrscheinlich auf eine gute Genauigkeit schätzen, indem Sie linear vom Ende dieser Werte extrapolieren (welche übersetzt in ein Potenzgesetz) und Integration der Extrapolationsfunktion ins Unendliche. Um diese Beispielberechnung abzuschließen, benötigen Sie auch den ersten Term. Dies ergibt eine sechsstellige Genauigkeit durch nur 29 berechnete Terme in der Summe.
(3) Beachten Sie, dass die Funktion wirklich von und abhängt , nicht von allen drei dieser Variablen unabhängig voneinander. Die Abhängigkeit von ist schwach (wie es sein sollte); Möglicherweise geben Sie sich damit zufrieden, den Wert während all Ihrer Berechnungen festzulegen.h/σ μ/σ T
(4) Darüber hinaus sollten Sie einige Serienbeschleunigungsmethoden wie die Aitken-Methode in Betracht ziehen . Eine gute Darstellung hierzu finden Sie in Numerical Recipes .
Hinzugefügt
(5) Sie können den Schwanz der Summe mit einem Integral schätzen. Beim Schreiben von kann die Gleichung (mit ) gelöst werden für , das klein ist, und dann für durch Ersetzen zurück. Das Erweitern der Tangente in einer Taylor-Reihe in ergibt die ungefähre Lösung tan ( θ n ) = θ n / & agr; & agr; = μ h / σ 2 t n θ n t nθn=(n+1/2)π−1/tn tan(θn)=θn/α α=μh/σ2 tn θn tn
wobei .z=(n+1/2)π
Vorausgesetzt, ist ausreichend groß, sind die Exponentialfaktoren der Form wird extrem nahe an 1, so dass Sie sie vernachlässigen können. Typischerweise können diese Begriffe auch für kleine vernachlässigt werden weil ist , extrem schnell die ersten exponentiellen Sprung auf Null zu machen. (Dies geschieht, sobald wesentlich überschreitet . Führen Sie Ihre Berechnungen für großes wenn Sie können!)1 - exp ( - & sgr; 2 & thgr ; 2 n T.n n& thgr; 2 n Θ(n2)nα/T1/2T1−exp(−σ2θ2nT2h2)exp(−μ2T2σ2) n θ2n Θ(n2) n α/T1/2 T
Wenn wir diesen Ausdruck für um die Terme für und zu summieren, können wir sie (sobald der gesamte Rauch verschwunden ist) als approximieren n n + 1θn n n+1
Das Ersetzen der Summe beginnend bei durch ein Integral über beginnend bei nähert sich dem Schwanz an. (Das Integral muss mit einem gemeinsamen Faktor von multipliziert werden .) Der Fehler im Integral ist . Um drei signifikante Zahlen zu erhalten, müssen Sie normalerweise ungefähr acht der Terme in der Summe berechnen und dann diese Endnäherung hinzufügen.N N - 1 / 4 exp ( - α ) O ( 1 / n 4 )n=2N N N−1/4 exp(−α) O(1/n4)
quelle
Sie können sich zunächst die Drawdown-Verteilungsfunktionen in fBasics ansehen . Sie können also leicht die Brownsche Bewegung mit Drift simulieren und diese Funktionen als Start anwenden.
quelle