Labfans是一个针对大学生、工程师和科研工作者的技术社区。 论坛首页 | 联系我们(Contact Us)
MATLAB爱好者论坛-LabFans.com
返回   MATLAB爱好者论坛-LabFans.com > 工程数学软件 > MATLAB论坛
MATLAB论坛 一切MATLAB相关问题在此讨论。
回复
 
主题工具 显示模式
旧 2010-04-22, 09:04   #1
zhaoguoxi
初级会员
 
注册日期: 2010-04-22
年龄: 45
帖子: 1
声望力: 0
zhaoguoxi 正向着好的方向发展
不错 大侠帮看看这段matlab程序错在哪里

一直出现提示
??? Error using ==> fmincon
FMINCON cannot continue because user supplied objective function
failed with the following error:

Index exceeds matrix dimensions.

我的程序如下:
q0=[0 0 0.5 0.5 0 0 2];aeq=[1 1 1 1 1 1 0; 1 2 3 4 5 6 -0.89298];
beq=[1; 0];A=[];b=[];vlb=[0 0 0 0 0 0 2];vub=[1 1 1 1 1 1 10];
[q,fun]=fmincon('objectfun',A,b,aeq,beq,vlb,vub,'ncon')

function fun=obfun(q)
clear;
n=6;s=zeros(n+1,1);g=zeros(n+1,1);h=zeros(41,1);
x=linspace(0,2,41);
for k=1:41
for j=1:n
for i=0:j-1
s(j)=s(j)+(q(7)*x(k))^i*exp(-q(7)*x(k))/factorial(i);
end
g(j)=q(j)*s(j);
end
h(k)=abs(exp(-x(k)^2)-sum(g));
end
fun=sum(h);

function [gc,ceq]=ncon(q)
gc=[];
ceq=[2*q(1)+6*q(2)+12*q(3)+20*q(4)+30*q(5)+42*q(6)-0.902705*q(7)^2];
zhaoguoxi 当前离线   回复时引用此帖
回复

主题工具
显示模式

发帖规则
不可以发表新主题
不可以发表回复
不可以上传附件
不可以编辑自己的帖子

启用 BB 代码
论坛启用 表情符号
论坛启用 [IMG] 代码
论坛禁用 HTML 代码



所有时间均为北京时间。现在的时间是 12:34


Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.