跪求Matlab大神解答,下面程序哪个地方出问题了?程序运行时一直报错 25
原代码:functionx=Problem_1()clearall%x是1408个r的解向量%把函数Problem_1()文件和ProblemData_6数据保存放在桌面...
原代码:
function x=Problem_1()
clear all
% x是1408个r的解向量
% 把函数Problem_1()文件和ProblemData_6数据保存放在桌面或者指定的matlab搜索文件夹(Current Folder设置)下
% 在Command Window里面输入x=Problem_1()即可得到x
clc
load ProblemData_6
x=zeros(1,length(P));
% 初始值
r0=0;
for i=1:length(P)
x(i)=fsolve(@(r)myfun(r,P(i),B(i,:),FROM(i,:)),r0);
end
x=x';
end
% 求解的r的函数
function y = myfun(r,P,B,FROM)
F=B(1);
for i=1:13
if i<13
F=F+(FROM(i)-r)*B(i)/((1+r)^i);
else
F=F+(FROM(i)-r)*B(i)/(r*(1+r)^12);
end
end
y=P-F;
% 求解y等于0
end
matlab报错如下:
Error using trustnleqn (line 28)
Objective function is returning undefined values at initial point. FSOLVE cannot continue.
Error in fsolve (line 397)
[x,FVAL,JACOB,EXITFLAG,OUTPUT,msgData]=...
Error in Problem_1 (line 12)
x(i)=fsolve(@(r)myfun(r,P(i),B(i,:),FROM(i,:)),r0); 展开
function x=Problem_1()
clear all
% x是1408个r的解向量
% 把函数Problem_1()文件和ProblemData_6数据保存放在桌面或者指定的matlab搜索文件夹(Current Folder设置)下
% 在Command Window里面输入x=Problem_1()即可得到x
clc
load ProblemData_6
x=zeros(1,length(P));
% 初始值
r0=0;
for i=1:length(P)
x(i)=fsolve(@(r)myfun(r,P(i),B(i,:),FROM(i,:)),r0);
end
x=x';
end
% 求解的r的函数
function y = myfun(r,P,B,FROM)
F=B(1);
for i=1:13
if i<13
F=F+(FROM(i)-r)*B(i)/((1+r)^i);
else
F=F+(FROM(i)-r)*B(i)/(r*(1+r)^12);
end
end
y=P-F;
% 求解y等于0
end
matlab报错如下:
Error using trustnleqn (line 28)
Objective function is returning undefined values at initial point. FSOLVE cannot continue.
Error in fsolve (line 397)
[x,FVAL,JACOB,EXITFLAG,OUTPUT,msgData]=...
Error in Problem_1 (line 12)
x(i)=fsolve(@(r)myfun(r,P(i),B(i,:),FROM(i,:)),r0); 展开
1个回答
2015-12-12
展开全部
我只发现一个问题,就是function y的结果后面不能加end;
还有好像在x=x'后面的end也是多余的
报错信息是初始点没有定义,但是貌似前面已定义了r0=0,似乎没有错
还有好像在x=x'后面的end也是多余的
报错信息是初始点没有定义,但是貌似前面已定义了r0=0,似乎没有错
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询