matlab下标分配维度不匹配。
问题描述:
我已经构建了这个脚本,但是我找不到Matrix中的问题。 这是我的答复脚本调用标准选项:matlab下标分配维度不匹配。
N=50;
T=90/252;
dt=T/N;
K=102;
S0=100;
B0=1;
r=0.02;
sigma=0.25;
for i=1:N
ttomat(i)=(N-i+1)*dt; %+1 serve per aggiustare il tempo
d1(i)=(log(S(i,:)./K)+(r+0.5*sigma^2)*ttomat(i))./(sigma*sqrt(ttomat(i)));
d2(i)=d1(i)-sigma*sqrt(ttomat(i));
Call(i,:)=S(i,:).*normcdf(d1(i))-K*exp(-r*ttomat(i)*normcdf(d2(i)));
alpha(i,:)=normcdf(d1(i)); %delta della Call
beta(i,:)=(Call(i,:)-alpha(i,:).*S(i,:))./(B0*exp(r*(i-1)*dt));
end
答
你必须初始化/预分配的结果,得到的循环计算。在你的代码中,你没有预先分配结果。预先分配可帮助您快速实现结果。预先分配所需的变量始终是最佳做法。检查下面的代码,它是否适合你?
N=50;
T=90/252;
dt=T/N;
K=102;
S0=100;
B0=1;
r=0.02;
sigma=0.25;
S = rand(N,1) ;
ttomat = zeros(1,N) ;
d1 = zeros(1,N) ;
d2 = zeros(1,N) ;
Call = zeros(1,N) ;
alpha = zeros(1,N) ;
beta = zeros(1,N) ;
for i=1:N
ttomat(i)=(N-i+1)*dt; %+1 serve per aggiustare il tempo
d1(i)=(log(S(i,:)./K)+(r+0.5*sigma^2)*ttomat(i))./(sigma*sqrt(ttomat(i)));
d2(i)=d1(i)-sigma*sqrt(ttomat(i));
Call(i,:)=S(i,:).*normcdf(d1(i))-K*exp(-r*ttomat(i)*normcdf(d2(i)));
alpha(i,:)=normcdf(d1(i)); %delta della Call
beta(i,:)=(Call(i,:)-alpha(i,:).*S(i,:))./(B0*exp(r*(i-1)*dt));
end
+0
谢谢,现在脚本正常工作! –
+0
请注意,我已经取S一个大小为N * 1的随机矩阵。将其更改为您的案例数据。 –
S没有定义....至少指定它的尺寸... –
请仔细阅读本[如何对提问](http://stackoverflow.com/help/how-to-ask)并遵循其中的指导方针,通过附加信息来优化您的问题,例如代码和错误消息来描述您的编程问题。 – thewaywewere