Matrix Loop and Labelling

조회 수: 14 (최근 30일)
Joe Bannen
Joe Bannen 2018년 5월 30일
댓글: Joe Bannen 2018년 5월 31일
Hi
I am trying to generate paths for stock prices via Brownian Motion. The code works okay (I hope!), but I can't get it to output correctly:
mu=0.10;
sigma=0.05;
N=5; % Number of time steps
NSim=3; % Number of simulations
dt=sigma/sqrt(N);
S=zeros(NSim,N+1);
S0=100;
S(:,1)=100; % initial value
for k=1:NSim
for i=2:N+1
epsilon=randn;
S(k,i)=S(k,i-1)+S(k,i-1)*(mu*dt+sigma*epsilon*sqrt(dt));
end
end
plot(S')
xlim([0 N+1]);
xlabel('Trading Days');
ylabel('Simulated Asset Price (£)');
However, the plot starts at 1 and finishes at 6. How can I make it start at 0 and stop at 5?
I think something has gone wrong with my loops!
Cheers
Joe

채택된 답변

dpb
dpb 2018년 5월 30일
You didn't supply an x to PLOT() so it plots versus ordinal number...
...
x=[0:N].'; % define range of x axis
plot(x,S')
...
  댓글 수: 1
Joe Bannen
Joe Bannen 2018년 5월 31일
Brilliant!
Many thanks
Joe

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Loops and Conditional Statements에 대해 자세히 알아보기

태그

제품

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by