24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1255  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 304求调剂 +7 c297914 2026-04-05 8/400 2026-04-05 22:13 by hemengdong
[考研] 086000生物与医药298调剂求助 +9 元元青青 2026-03-31 12/600 2026-04-05 21:03 by 学员8dgXkO
[考研] 材料0856 英一数二 323 求调剂 +14 袁sy 2026-04-01 14/700 2026-04-05 18:18 by cql1109
[考研] 284求调剂 +7 徐同学_001 2026-04-04 13/650 2026-04-05 17:19 by yulian1987
[考研] 301求调剂 +12 121. 2026-04-04 12/600 2026-04-05 09:00 by 来看流星雨10
[考博] 申博 +7 IQwQl 2026-04-04 7/350 2026-04-04 23:32 by mumin1990
[考研] 一志愿郑州大学材料与化工085600,求调剂 +24 吃的不少 2026-04-02 24/1200 2026-04-04 23:20 by 永字号
[考研] 325求调剂 +4 春风不借意 2026-04-04 4/200 2026-04-04 22:08 by 啵啵啵0119
[考研] 求调剂 +4 晟功? 2026-04-03 4/200 2026-04-04 21:58 by hemengdong
[考研] 349求调剂 +11 zwjjjjjj 2026-03-31 11/550 2026-04-04 19:52 by 蓝云思雨
[考研] 357求调剂 +13 1050389037 2026-04-03 13/650 2026-04-03 22:27 by 无际的草原
[考研] 266求调剂 +18 阳阳哇塞 2026-04-01 18/900 2026-04-03 18:38 by zllcz
[考研] 320求调剂 +5 振—TZ 2026-04-02 5/250 2026-04-03 14:42 by fxue1114
[考研] 英一数一408,总分284,二战真诚求调剂 +13 12.27 2026-03-30 15/750 2026-04-03 14:41 by 氮气气气
[考研] 08工科,295,接受跨专业调剂 +8 lmnlzy 2026-03-30 8/400 2026-04-03 13:08 by nalakaiqi
[考研] 338求调剂,一志愿能源动力,外语是日语203 +5 zzz,,r 2026-04-02 5/250 2026-04-03 09:45 by 蓝云思雨
[考研] 285求调剂 +8 AZMK 2026-04-02 11/550 2026-04-02 20:16 by yulian1987
[考研] 266求调剂 +4 学员97LZgn 2026-04-02 4/200 2026-04-02 09:52 by yulian1987
[考研] 318求调剂 +8 七忆77 2026-04-01 8/400 2026-04-01 10:37 by Jaylen.
[考研] 一志愿浙江大学工科动力工程370,数一121,专业课135,现在能去哪里 +3 080700调剂 2026-03-30 4/200 2026-03-31 12:00 by KLMY666
信息提示
请填处理意见