Calculate 10y returns out of monthly data
1 view (last 30 days)
Show older comments
hey guys,
i have monthly returns (1mil. simulations). Now i want to calculate corresponding 10 year returns. for example vextor x: 0.05 0.02 0.03 0.4 -0.21 ...
what matlab should do now is to calculate: ((1+r(1))*(1+r(2))*...(1+r(120)))-1 and ((1+r(121))*(1+r(122))*...(1+r(240)))-1 and so on...
thx for your help
0 Comments
Accepted Answer
Andrei Bobrov
on 24 Oct 2014
Edited: Andrei Bobrov
on 24 Oct 2014
out = prod(1 + reshape(x,120,[])) - 1;
or
out = accumarray(ceil((1:numel(x))'/120),x(:),[],@(x)prod(1+x)-1);
0 Comments
More Answers (1)
Roger Wohlwend
on 24 Oct 2014
y = exp(filter(ones(120,1),1,log(1+r)))-1;
y = y(120:end);
2 Comments
Roger Wohlwend
on 24 Oct 2014
Oh, my mistake.
y = exp(filter(ones(120,1),1,log(1+r)))-1;
y = y(120:120:end);
See Also
Categories
Find more on MATLAB Report Generator in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!