-
Notifications
You must be signed in to change notification settings - Fork 197
/
Copy pathkellyCapAlloc.m
61 lines (34 loc) · 2.21 KB
/
kellyCapAlloc.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
% kellyCapAlloc.m
clear; % make sure previously defined variables are erased.
[num1, txt1]=xlsread('OIH'); % read a spreadsheet named "OIH.xls" into MATLAB.
tday1=txt1(2:end, 1); % the first column (starting from the second row) is the trading days in format mm/dd/yyyy.
tday1=datestr(datenum(tday1, 'mm/dd/yyyy'), 'yyyymmdd'); % convert the format into yyyymmdd.
tday1=str2double(cellstr(tday1)); % convert the date strings first into cell arrays and then into numeric format.
adjcls1=num1(:, end); % the last column contains the adjusted close prices.
[num2, txt2]=xlsread('RKH'); % read a spreadsheet named "RKH.xls" into MATLAB.
tday2=txt2(2:end, 1); % the first column (starting from the second row) is the trading days in format mm/dd/yyyy.
tday2=datestr(datenum(tday2, 'mm/dd/yyyy'), 'yyyymmdd'); % convert the format into yyyymmdd.
tday2=str2double(cellstr(tday2)); % convert the date strings first into cell arrays and then into numeric format.
adjcls2=num2(:, end);
[num3, txt3]=xlsread('RTH'); % read a spreadsheet named "RTH.xls" into MATLAB.
tday3=txt3(2:end, 1); % the first column (starting from the second row) is the trading days in format mm/dd/yyyy.
tday3=datestr(datenum(tday3, 'mm/dd/yyyy'), 'yyyymmdd'); % convert the format into yyyymmdd.
tday3=str2double(cellstr(tday3)); % convert the date strings first into cell arrays and then into numeric format.
adjcls3=num3(:, end);
% merge these data
tday=union(tday1, tday2);
tday=union(tday, tday3);
adjcls=NaN(length(tday), 3);
[foo idx1 idx]=intersect(tday1, tday);
adjcls(idx, 1)=adjcls1(idx1);
[foo idx2 idx]=intersect(tday2, tday);
adjcls(idx, 2)=adjcls2(idx2);
[foo idx3 idx]=intersect(tday3, tday);
adjcls(idx, 3)=adjcls3(idx3);
ret=(adjcls-backshift(1, adjcls))./backshift(1, adjcls); % returns
baddata=find(any(~isfinite(ret), 2)); % days where any one return is missing
ret(baddata, :)=[]; % eliminate days where any one return is missing
excessRet=ret-repmat(0.04/252, size(ret)); % excess returns: assume annualized risk free rate is 4%
M=252*mean(excessRet, 1)' % annualized mean excess returns
C=252*cov(excessRet) % annualized covariance matrix
F=inv(C)*M % Kelly optimal leverages