24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1276  |  回复: 7
当前主题已经存档。

liuyong2007

金虫 (小有名气)

[交流] 【求助】用Matlab求解动力学方程参数的估计问题,程序运行有错误【已完成】

哪位帮帮我,谢谢了.我用龙阁库塔积分和非线性最小二乘估计动力学参数,但是有错误.请高手指点一下,谢谢.程序如下:



function KineticsEst1_int
% 动力学方程为rA=dCA/dt=k1*CA*CB-k2*CC
clear all
clc
global CAm CBm CCm
t = [0 20  40  60  120  180  300];
CAm = [10  8  6  5  3  2  1]';
CBm = [8  7  6  5  3  2  1]';
CCm = [0 5  7  8 10  12  14]';
% 非线性拟合
beta0 = [0.0053 1.39];
tspan = [0 20  40  60  120  180  300];
CA0 = 10;
[beta,resnorm,resid,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@OptObjFunc,beta0,[],[],[],tspan,CA0,CAm,CBm,CCm)
ci = nlparci(beta,resid,jacobian)
% 拟合效果图(实验与拟合的比较)
[t4plot CA4plot] = ode45(@KineticsEqs,[tspan(1)  tspan(end)],CA0,[],beta);
plot(t,CAm,'bo',t4plot,CA4plot,'k-')
legend('Exp','Model')
xlabel('时间t, s')
ylabel('浓度C_A, mol/L')
% 参数辨识结果
fprintf('Estimated Parameters:\n')
fprintf('\tk1 = %.4f ± %.4f\n',beta(1),ci(1,2)-beta(1))
fprintf('\tk2 = %.4f ± %.4f\n',beta(2),ci(2,2)-beta(2))
% ------------------------------------------------------------------
function f = OptObjFunc(beta,tspan,CA0,CAm)
[t CAc] = ode45(@KineticsEqs,tspan,CA0,[],beta);
f = CAc - CAm;
% ------------------------------------------------------------------
function dCAdt = KineticsEqs(t,CA,CB,CC,beta)
dCAdt = beta(1)*CA*CB-beta(2)*CC;            % k1= beta(1), k2= beta(2)

[ Last edited by nono2009 on 2009-9-23 at 21:15 ]
回复此楼

» 收录本帖的淘帖专辑推荐

matlab

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

allenhero1228

金虫 (小有名气)

★ ★
woshilsh(金币+2,VIP+0):thanks for your help!
你的目标函数是KineticsEqs(t,CA,CB,CC,beta),beta是你要拟合的参数,剩下的是形参,需要你输入。以你现在的顺序在计算过程中可能是这样,tspan赋给t,CA0赋给CA,CAM赋给CB,CBm赋给CC,CCm赋给beta,这样程序里面就没有你要拟合的参数,程序就没法进行计算。
好像是应该把beta放在最前面
以上是我的想法,不知道对不对,希望后面有牛人给你正确详细的回答
另外建议你把matlab中给你的错误提示也发上来
2楼2008-12-11 12:33:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liuyong2007

金虫 (小有名气)

mat;ab提示错误信息,希望高手给我改改

??? Error using ==> optim\private\lsqncommon
User supplied function ==> OptObjFunc
failed with the following error:

Error using ==> KineticsEst1_int22>OptObjFunc
Too many input arguments.

Error in ==> lsqnonlin at 163
[x,Resnorm,FVAL,EXITFLAG,OUTPUT,LAMBDA,JACOB] = ...

Error in ==> KineticsEst1_int22 at 17
[beta,resnorm,resid,exitflag,output,lambda,jacobian] = ...
3楼2008-12-11 12:41:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

allenhero1228

金虫 (小有名气)


coldwind042(金币+1,VIP+0):谢谢帮助!
你试试把beta放在最前面,然后在global中把CA CB CC加上,而且我看你想把CA0,CAm,CBm,CCm都赋给函数,但函数里面只有三个形参,是不是应该把CA0,CAm,CBm,CCm中的某个变量给去了
4楼2008-12-11 13:06:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snipher950

木虫 (正式写手)

你自定义函数之间的参数传递有问题。给你改改……
5楼2008-12-11 14:20:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snipher950

木虫 (正式写手)

★ ★ ★ ★ ★
woshilsh(金币+5,VIP+0):感谢回答!支持热心虫友,常来!呵呵!
可以运行了,改了很多地方,你自己琢磨一下。只不过结果不对,那是因为你的实验数据是虚假的,Matlab拟和不出来好的结果。

function KineticsEst1_int
% 动力学方程为rA=dCA/dt=k1*CA*CB-k2*CC
clear all
clc
global CAm CBm CCm
t = [0 20  40  60  120  180  300];
CAm = [10  8  6  5  3  2  1]';
CBm = [8  7  6  5  3  2  1]';
CCm = [0 5  7  8 10  12  14]';
% 非线性拟合
beta0 = [0.0000053 10];
tspan = [0 20  40  60  120  180  300];
CA0 = 10;
CB0 = 8;
CC0 = 0;
[beta,resnorm,resid,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@OptObjFunc,beta0,[0 0],[],[],tspan,[CA0 CB0 CC0])
ci = nlparci(beta,resid,jacobian)
% 拟合效果图(实验与拟合的比较)
[t4plot CA4plot] = ode45(@KineticsEqs,[tspan(1)  tspan(end)],[CA0 CB0 CC0],[],beta);
plot(tspan,CAm,'bo',t4plot,CA4plot(:,1),'k-')
legend('Exp','Model')
xlabel('时间t, s')
ylabel('浓度C_A, mol/L')
% 参数辨识结果
fprintf('Estimated Parameters:\n')
fprintf('\tk1 = %.4f ± %.4f\n',beta(1),ci(1,2)-beta(1))
fprintf('\tk2 = %.4f ± %.4f\n',beta(2),ci(2,2)-beta(2))
% ------------------------------------------------------------------
function f = OptObjFunc(beta,tspan,CA0)
global CAm CBm CCm
[t Y] = ode45(@KineticsEqs,tspan,CA0,[],beta);
if length(t)==length(tspan)
    f = Y - [CAm CBm CCm];
else
    f=100000;
end
% ------------------------------------------------------------------
function dy = KineticsEqs(t,Y,beta)
CA=Y(1);
CB=Y(2);
CC=Y(3);
dCAdt = beta(1)*CA*CB-beta(2)*CC;            % k1= beta(1), k2= beta(2)
dCBdt = beta(1)*CA*CB-beta(2)*CC;
dCCdt = beta(2)*CC;
dy=[dCAdt;dCBdt;dCCdt];
6楼2008-12-11 14:35:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liuyong2007

金虫 (小有名气)

谢谢楼上,我再把实验数据带到里面试试.
7楼2008-12-11 18:50:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

apolloking

金虫 (小有名气)

★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
sunxiao(金币+2,VIP+0):鼓励新虫参与讨论 7-18 05:29
楼主应用的是间歇式反应器吧
所以能够得到不同时刻的浓度值
8楼2009-07-17 18:58:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 liuyong2007 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[教师之家] 又一批高校组建人工智能学院 师资行吗 不是骗人吗 +6 yexuqing 2026-04-19 7/350 2026-04-23 12:32 by yexuqing
[基金申请] 国自然面上和省基金B类撒花 +18 花田半亩~白 2026-04-21 18/900 2026-04-23 11:31 by 12021227
[考研] 有没有学校收留 +3 蒋昌鹏qtj 2026-04-20 3/150 2026-04-22 20:25 by 学员JpLReM
[考研] 312求调剂 +3 山河似你温柔 2026-04-22 3/150 2026-04-22 20:17 by 学员JpLReM
[考博] 华师大读博 +3 xq83 2026-04-22 5/250 2026-04-22 10:42 by xq83
[论文投稿] 急需审稿人!!! +3 陆小果画大饼 2026-04-21 3/150 2026-04-21 23:54 by jzy_123456
[考研] 295分求调剂 +6 ?要上岸? 2026-04-17 6/300 2026-04-21 08:18 by Equinoxhua
[考研] 085600材料与化工调剂 5+3 孜孜不倦2002 2026-04-19 6/300 2026-04-20 21:25 by babero
[论文投稿] 有没有接收比较快的sci期刊呀,最好在一个月之内的,研三孩子求毕业 20+4 之护着 2026-04-16 7/350 2026-04-20 15:45 by 豆豆7758
[考研] 337求调剂 +3 jyz04 2026-04-18 3/150 2026-04-20 12:24 by 研可安
[考博] 申博 +3 Xyyx. 2026-04-18 3/150 2026-04-20 10:44 by YuY66
[考博] 湖南大学刘巧玲课题组2026年第二批次博士研究生招生信息 +3 南风观火 2026-04-18 5/250 2026-04-20 10:13 by 南风观火
[考研] 求计算机方向调剂 +3 Toffee2 2026-04-16 6/300 2026-04-19 22:37 by ll叶
[考研] 294求调剂 +8 淡然654321 2026-04-17 9/450 2026-04-19 19:51 by Equinoxhua
[考研] 304求调剂 +8 castLight 2026-04-16 8/400 2026-04-19 17:14 by 中豫男
[考研] 求调剂 +6 苦命人。。。 2026-04-18 7/350 2026-04-19 16:27 by 中豫男
[考研] 接受任何调剂 +6 也就是栗子 2026-04-17 7/350 2026-04-18 17:20 by 涵竹刘
[考研] 260求调剂 +4 Zyt1314520.. 2026-04-17 5/250 2026-04-18 08:28 by babysonlkd
[有机交流] 二苯甲酮酸类衍生物 50+3 小白爱主人 2026-04-17 6/300 2026-04-17 18:47 by kf2781974
[考研] 322求调剂 +6 tekuzu 2026-04-17 6/300 2026-04-17 13:48 by Espannnnnol
信息提示
请填处理意见