24小时热门版块排行榜    

查看: 738  |  回复: 1
【悬赏金币】回答本帖问题,作者臣本布衣将赠送您 150 个金币

臣本布衣

新虫 (初入文坛)

[求助] 求助matlab进行反应动力学拟合,大神帮忙看看代码哪里有问题 已有1人参与

动力学方程如下:

(dC_A)/dt=-(k_1+k_2)*K_A*C_A/(1+K_A*C_A+K_B*C_B+K_C*C_C+K_D*C_D+K_E*C_E)
(dC_B)/dt=k_1*K_A*C_A/(1+K_A*C_A+K_B*C_B+K_C*C_C+K_D*C_D+K_E*C_E)
(dC_C)/dt=(k_2*K_A*C_A-(k_3+k_4)*K_C*C_C+k_5*K_E*C_E)/(1+K_A*C_A+K_B*C_B+K_C*C_C+K_D*C_D+K_E*C_E)
(dC_D)/dt=k_3*K_C*C_C/(1+K_A*C_A+K_B*C_B+K_C*C_C+K_D*C_D+K_E*C_E)
(dC_E)/dt=(k_4*K_C*C_C-k_5*K_E*C_E)/(1+K_A*C_A+K_B*C_B+K_C*C_C+K_D*C_D+K_E*C_E)

用matlab语言的ode45解算子求上述微分方程组,以各物质浓度计算值和实验值的残差平方和为目标函数,用lsqnonline解算子求解上述最优化问题。
代码如下:

function piadatfit
clc; clear all; close all;
%己烯异构化反应动力学数据拟合%输入实验数据
tspan=[0 30 36 45 60 90 180];
cexp=[0.84691 0 0 0 0;
    0.65164 0 0.10305 0.02491 0.00485;
     0.65409 0 0.11407 0.02995 0.00681;
     0.60309 0 0.14508 0.03510 0.00949;
      0.08397 0 0.65655 0.04303 0.01346;
      0.05952 0.00752 0.61224 0.05047 0.01814;
      0 0.05346 0.53471 0.06414 0.02753];
c0=[0.84691 0 0 0 0];
%输入参数初值及范围
k0=[0.1 2 0.05 0.05 0.05 0.3 0.3 0.3 0.1 0.1];
lb=[0 0 0 0 0 0 0 0 0 0];
ub=[10 10 10 10 10 10 10 10 10 10];
%非线性最小二乘拟合
options.algorithm = 'levenberg-marquardt';
[k,resnorm,residual,exitflag,output,lambda,jacobian]=lsqnonlin(@objpia,k0,lb,ub,options,cexp,tspan,c0)
%拟合结果标绘
[tplot,cplot]=ode45(@piakin,tspan,c0,[],k);
plot(tspan,cexp(:,1),'bx',tplot,cplot(:,1),'b-',tspan,cexp(:,2),'ko',tplot,cplot(:,2),'k-',tspan,cexp(:,3),'g*',tplot,cplot(:,3),'g-',tspan,cexp(:,4),'rs',tplot,cplot(:,4),'r-',tspan,cexp(:,5),'cd',tplot,cplot(:,5),'c-')
xlabel('time(min)')
ylabel('concentration(mol/l)')
legend('caexp','cacal','cbexp','cbcal','ccexp','cccal','cdexp','cdcal','ceexp','cecal')

function f=objpia(k0,cexp,tspan,c0)
%最小二乘拟合目标函数
[t,c]=ode45(@piakin,tspan,c0,[],k0);
f1=c(:,1)-cexp(:,1);
f2=c(:,2)-cexp(:,2);
f=[f1;f2];

function dcdt=piakin(t,c,k)
%反应动力学方程
r1=k(1)*k(6)*c(1)/(1+k(6)*c(1)+k(7)*c(2)+k(8)*c(3)+k(9)*c(4)+k(10)*c(5));
r2=k(2)*k(6)*c(1)/(1+k(6)*c(1)+k(7)*c(2)+k(8)*c(3)+k(9)*c(4)+k(10)*c(5));
r3=k(3)*k(8)*c(3)/(1+k(6)*c(1)+k(7)*c(2)+k(8)*c(3)+k(9)*c(4)+k(10)*c(5));
r4=k(4)*k(8)*c(3)/(1+k(6)*c(1)+k(7)*c(2)+k(8)*c(3)+k(9)*c(4)+k(10)*c(5));
r5=k(5)*k(10)*c(5)/(1+k(6)*c(1)+k(7)*c(2)+k(8)*c(3)+k(9)*c(4)+k(10)*c(5));
dcdt(1)=-r1-r2;
dcdt(2)=r1;
dcdt(3)=r2-r3-r4+r5;
dcdt(4)=r3;
dcdt(5)=r4-r5;
dcdt=dcdt';

matlab小白,程序是模仿教材写的,应该存在不少问题,请大神帮忙修改一下!
回复此楼
爱拼才会赢
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
微分方程拟合问题,1stOpt试试,更简单、方便:

Sum Squared Error (SSE): 0.257211769123463
Root of Mean Square Error (RMSE): 0.0925944147205909
Correlation Coef. (R): 0.867645804757432
R-Square: 0.752809242513172

Parameter        Best Estimate      
---------        -------------      
k1               0.00075219124176959
k2               0.0093680714188618  
k3               0.0883840107805217  
k4               9.99999999961713   
k5               9.99999999989503   
k6               9.99999999999999   
k7               4.61483024965692E-14
k8               0.0268675102514994  
k9               5.40027468998149E-19
k10              0.307240694154773
2楼2022-08-13 12:58:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 臣本布衣 的主题更新
不应助 确定回帖应助 (注意:应助才可能被奖励,但不允许灌水,必须填写15个字符以上)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 本人考085602 化学工程 专硕 +7 不知道叫什么! 2026-03-15 8/400 2026-03-15 20:11 by 棒棒球手
[考博] 欢迎申博同学联系 +3 天道酬勤2026686 2026-03-10 7/350 2026-03-15 19:03 by 天道酬勤2026686
[考研] 0703化学调剂 290分有科研经历,论文在投 +3 腻腻gk 2026-03-14 3/150 2026-03-15 17:28 by 小物理化学
[基金申请] 国自科面上基金字体 +4 iwuli 2026-03-12 5/250 2026-03-15 17:07 by 风云无泪
[考研] 289求调剂 +4 这么名字咋样 2026-03-14 6/300 2026-03-14 18:58 by userper
[考研] 306求调剂 +4 唐薏薏 2026-03-09 4/200 2026-03-14 01:19 by JourneyLucky
[考研] 341求调剂 +3 番茄头--- 2026-03-10 3/150 2026-03-13 23:07 by JourneyLucky
[考研] 材料专硕288分求调剂 一志愿211 +4 在家想你 2026-03-11 4/200 2026-03-13 22:49 by JourneyLucky
[考研] 材料工程调剂 +9 咪咪空空 2026-03-12 9/450 2026-03-13 22:05 by 星空星月
[考研] 求材料调剂 085600英一数二总分302 前三科235 精通机器学习 一志愿哈工大 +4 林yaxin 2026-03-12 4/200 2026-03-13 22:04 by 星空星月
[考研] 333求调剂 +3 球球古力 2026-03-11 3/150 2026-03-13 21:27 by JourneyLucky
[考研] 285化工学硕求调剂(081700) +6 柴郡猫_ 2026-03-12 6/300 2026-03-13 20:46 by hmn_wj
[考研] 材料专硕350 求调剂 +4 王金科 2026-03-12 4/200 2026-03-13 16:02 by ruiyingmiao
[考研] 一志愿211化学学硕310分求调剂 +8 努力奋斗112 2026-03-12 9/450 2026-03-13 15:41 by JourneyLucky
[考研] 295求调剂 +3 小匕仔汁 2026-03-12 3/150 2026-03-13 15:17 by vgtyfty
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 材料301分求调剂 +5 Liyouyumairs 2026-03-12 5/250 2026-03-13 14:42 by JourneyLucky
[考研] 296求调剂 +3 大口吃饭 身体健 2026-03-13 3/150 2026-03-13 10:31 by 学员8dgXkO
[考研] 270求调剂 085600材料与化工专硕 +3 YXCT 2026-03-11 3/150 2026-03-13 10:13 by houyaoxu
[考研] 420求调剂 +4 莫向外求11 2026-03-10 6/300 2026-03-12 14:41 by ruiyingmiao
信息提示
请填处理意见