Log Returns of Stock Prices
Stock prices modeled with geometric Brownian motion (in the classical Black–Scholes model) are assumed to be normally distributed in their log returns. Here, this assumption is examined with the stock prices of five companies: Google, Microsoft, Facebook, Apple, and Intel.
Retrieve the stock prices in 2015 with FinancialData.
data:image/s3,"s3://crabby-images/d677d/d677d6f9f1b0e7f60a392b50d617df3d35a0b48a" alt="Click for copyable input"
symbols = {"GOOGL", "MSFT", "FB", "AAPL", "INTC"};
prices = Table[
FinancialData[stock, {{2015, 1, 1}, {2015, 12, 31}}], {stock,
symbols}];
Compute the log returns.
data:image/s3,"s3://crabby-images/181c3/181c37e70682650c46f177b599810122cfc386dc" alt="Click for copyable input"
logreturn = Minus[Differences[Log[prices[[All, All, 2]]], {0, 1}]];
Filter the log returns with an ARCHProcess of order 1.
data:image/s3,"s3://crabby-images/ccff8/ccff839956303fe17beccd118b6dc8d983aab1b0" alt="Click for copyable input"
fdata = Table[
{\[Kappa]1, \[Alpha]1} = {\[Kappa], \[Alpha]} /.
FindProcessParameters[lr, ARCHProcess[\[Kappa], {\[Alpha]}]];
MovingMap[Last[#]/Sqrt[\[Kappa]1 + \[Alpha]1 First[#]^2] &, lr, 2]
, {lr, logreturn}];
fdata = Transpose[fdata];
Compare the filtered data from each stock to the normal distribution with QuantilePlot. For all five companies, the tails deviate from normal.
data:image/s3,"s3://crabby-images/b1809/b1809f8d1699fe821ea86ae2dc8c722b3ea5e34f" alt=""
Perform a multivariate normality test with BaringhausHenzeTest (BHEP). The normality assumption is clearly rejected.
data:image/s3,"s3://crabby-images/a503c/a503c01ad114ff9f84495ebbd72be5512ae5c80e" alt="Click for copyable input"
htd = BaringhausHenzeTest[fdata, "HypothesisTestData"];
data:image/s3,"s3://crabby-images/870d0/870d0f8f89a6d3624791cf7168e5482cfd24eea5" alt="Click for copyable input"
htd["TestDataTable"]
data:image/s3,"s3://crabby-images/3488b/3488b3d2e97cfadec7987ec8336b1b54535dc361" alt=""
data:image/s3,"s3://crabby-images/916d4/916d41bad0bf98ce04f82b7acf48301fddae4494" alt="Click for copyable input"
htd["ShortTestConclusion"]
data:image/s3,"s3://crabby-images/7fd8d/7fd8d123a655986d538f2730f9088b5c2745f8d6" alt=""
Fit the filtered data with MultinormalDistribution and MultivariateTDistribution.
data:image/s3,"s3://crabby-images/3759c/3759ce7ecc6ad13d27ccd40feb343bcaaa341419" alt="Click for copyable input"
multiN = EstimatedDistribution[fdata,
MultinormalDistribution[Array[x, 5], Array[s, {5, 5}]]]
data:image/s3,"s3://crabby-images/93750/937507ff1d3bab1aaf81c64485564964f81aaca2" alt=""
data:image/s3,"s3://crabby-images/d6ef9/d6ef9a2d5d4e09ce3568a1d878c539beede4106e" alt="Click for copyable input"
multiT = EstimatedDistribution[fdata,
MultivariateTDistribution[Array[x, 5], Array[s, {5, 5}], nu]]
data:image/s3,"s3://crabby-images/a0b9f/a0b9f89b56131054a285339d504116ab984ec78b" alt=""
Compute the AIC for the two distributions. The model of MultivariateTDistribution has a smaller value.
data:image/s3,"s3://crabby-images/34bf2/34bf2a9757ccc57016b37f11785f1c3e941682f6" alt="Click for copyable input"
aic[k_, dist_, data_] := 2 k - 2 LogLikelihood[dist, data]
data:image/s3,"s3://crabby-images/4eecb/4eecbf0c47fcc7c6ce9d380fb712d41acabd3275" alt="Click for copyable input"
aic[5 + 15, multiN, fdata]
data:image/s3,"s3://crabby-images/8f053/8f053f06023411698a66d2f982954a34837d162c" alt=""
data:image/s3,"s3://crabby-images/96d37/96d37c1f060d72f3f3da5732c3cff27b41b2db8f" alt="Click for copyable input"
aic[5 + 15 + 1, multiT, fdata]
data:image/s3,"s3://crabby-images/02625/026257b697e04d6b3ea3efaff8fdaa96fa3b5087" alt=""