声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1126|回复: 8

[编程技巧] 求高人帮解决一下本程序的问题

[复制链接]
发表于 2008-9-5 17:30 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
最近本人应用Matlab计算反应动力学参数,遇到了点问题。特此向各位高人请教。
本人的程序如下:

clear all
clc
k0 = [0.5  0.5  0.5  0.5  0.5  0.5];      
lb = [0  0  0  0  0  0];                  
ub = [+inf  +inf  +inf  +inf  +inf  +inf];   
x0 = [0.7584  0.0000  0.0000  0.0000  6.8256  0.0000];
KineticsData65;
yexp = ExpData(:,2:7);                  

[k,fval,flag] = fmincon(@ObjFunc4Fmincon,k0,[],[],[],[],lb,ub,[],[],x0,yexp);
fprintf('\n使用函数fmincon()估计得到的参数值为:\n')
fprintf('\tk1 = %.4f\n',k(1))
fprintf('\tk2 = %.4f\n',k(2))
fprintf('\tk3 = %.4f\n',k(3))
fprintf('\tk4 = %.4f\n',k(4))
fprintf('\tk5 = %.4f\n',k(5))
fprintf('\tk6 = %.4f\n',k(6))
fprintf('  The sum of the squares is: %.1e\n\n',fval)
k_fmincon = k;

[k,resnorm,residual,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@ObjFunc4LNL,k0,lb,ub,[],x0,yexp);      
ci = nlparci(k,residual,jacobian);
fprintf('\n\n使用函数lsqnonlin()估计得到的参数值为:\n')
Output

k0 = k_fmincon;
[k,resnorm,residual,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@ObjFunc4LNL,k0,lb,ub,[],x0,yexp);      
ci = nlparci(k,residual,jacobian);
fprintf('\n\n以fmincon()的结果为初值,使用函数lsqnonlin()估计得到的参数值为:\n')
Output

% ------------------------------------------------------------------
function f = ObjFunc4Fmincon(k,x0,yexp)
tspan = [0.00 : 0.01 : 0.20];
[t x] = ode45(@KineticEqs,tspan,x0,[],k);   
y(:,1) = x(:,1);
y(:,2:5) = x(:,5:8);
f = sum((y(:,1)-yexp(:,1)).^2) + sum((y(:,2)-yexp(:,2)).^2)   ...
    + sum((y(:,3)-yexp(:,3)).^2) + sum((y(:,4)-yexp(:,4)).^2)+ sum((y(:,5)-yexp(:,5)).^2);
% ------------------------------------------------------------------
function f = ObjFunc4LNL(k,x0,yexp)
tspan = [0.00 : 0.01 : 0.20];
[t x] = ode45(@KineticEqs,tspan,x0,[],k);   
y(:,1) = x(:,1);
y(:,2:5) = x(:,5:8);
f1 = y(:,1) - yexp(:,1);
f2 = y(:,2) - yexp(:,2);
f3 = y(:,3) - yexp(:,3);
f4 = y(:,4) - yexp(:,4);
f5 = y(:,5) - yexp(:,5);
f = [f1; f2; f3; f4; f5];
% ------------------------------------------------------------------
function dxdt = KineticEqs(t,x,k)
dxdt =  ...
[ ( -k(1)*x(1)*x(5)+k(2)*x(2)*x(4) )
   ( k(1)*x(1)*x(5)-k(2)*x(2)*x(4)-K(3)*x(2)*x(5)+K(4)*x(3)*x(4) )
   ( K(3)*x(2)*x(5)-K(4)*x(3)*x(4)-k(5)*x(3)*x(5)+k(6)*x(4)*x(6) )
   ( K(1)*x(1)*x(5)-K(2)*x(2)*x(4)+K(3)*x(2)*x(5)-k(4)*x(3)*x(4)+k(5)*x(3)*x(5)-k(6)*x(4)*x(6) )
   ( -K(1)*x(1)*x(5)+K(2)*x(2)*x(4)-K(3)*x(2)*x(5)+k(4)*x(3)*x(4)-k(5)*x(3)*x(5)+k(6)*x(4)*x(6) )
   ( k(5)*x(3)*x(5)-k(6)*x(4)*x(6) )
];

出现的错误提示为:
Warning: Large-scale (trust region) method does not currently solve this type of problem,
switching to medium-scale (line search).
> In fmincon at 260
  In KineticsEst65 at 25
??? Error using ==> fmincon
FMINCON cannot continue because user supplied objective function failed with the following error:
Undefined command/function 'K'.
Error in ==> KineticsEst65 at 25
[k,fval,flag] = fmincon(@ObjFunc4Fmincon,k0,[],[],[],[],lb,ub,[],[],x0,yexp);

请哪位高人帮我修改一下程序,非常感谢!
回复
分享到:

使用道具 举报

发表于 2008-9-5 17:53 | 显示全部楼层
你是不是把大小写搞错了
 楼主| 发表于 2008-9-5 18:22 | 显示全部楼层

回复 沙发 sigma665 的帖子

全一致改成小写了,还是相同的问题!
这是怎么回事呢
 楼主| 发表于 2008-9-5 18:25 | 显示全部楼层

修正一下

经全部符号对照修改后
错误提示为
Warning: Large-scale (trust region) method does not currently solve this type of problem,
switching to medium-scale (line search).
> In fmincon at 260
  In KineticsEst65 at 25
??? Error using ==> fmincon
FMINCON cannot continue because user supplied objective function failed with the following error:
Index exceeds matrix dimensions.
Error in ==> KineticsEst65 at 25
[k,fval,flag] = fmincon(@ObjFunc4Fmincon,k0,[],[],[],[],lb,ub,[],[],x0,yexp);
发表于 2008-9-5 18:54 | 显示全部楼层

回复 地板 hwkai 的帖子

提示的意思是叫你用线搜索的方法
 楼主| 发表于 2008-9-5 19:32 | 显示全部楼层

回复 5楼 无水1324 的帖子

请教一下,我该如何实现线搜索呢!这方面我不太懂啊。能帮我改一下吗
发表于 2008-9-5 21:53 | 显示全部楼层
Index exceeds matrix dimensions.

仔细看看你的矩阵维数
发表于 2008-9-6 16:28 | 显示全部楼层
首先
你的ode45能不能解出答案
发表于 2008-9-6 17:36 | 显示全部楼层
看看初值赋值是不是超出了范围
提示的意思是说你选用的算法规模太大不适合这个问题,建议换成较小的线性搜索
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2025-1-12 19:54 , Processed in 0.096345 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表