24小时热门版块排行榜    

Znn3bq.jpeg
查看: 673  |  回复: 0

zhaoshazhu

新虫 (小有名气)

[求助] Matlab指导

这是我编的程序代码,但不知哪地方有问题,请高手帮忙指点一下。
function KineticsEstHydrogenation
%

clear all
clc
format long
%       KH   KDMM   KMe    KHPM   KPDO    k1     k2     k3
k0 = [2.780  4.049 3.225  1.540  2.456        27.967 42.249 10];
lb = [0 0 0 0 0 0 0 0];                   % 参数下限
ub = [+inf  +inf  +inf  +inf +inf +inf +inf  +inf];    % 参数上限
% 动力学数据:
% T =195
%  t     H2in   DMMin   Mein    HPMin   PDOin   NPAin   HPMout   PDOout NPAout
data=...
[2.05         0.00258         0.92932        0.06810         0        0        0        3.1360E-05        1.1642E-03        0.0011365;
1.37         0.00155         0.93029        0.06817         0        0        0        7.8438E-05        1.3477E-03        0.0005733;
1.62         0.00173         0.91758        0.08068         0        0        0        1.0444E-04        1.7271E-03        0.0004754;
1.98         0.00187         0.89928        0.09884         0        0        0        2.8942E-04        2.3631E-03        0.0004436;
1.21         0.00158         0.91772        0.08070         0        0        0        4.1373E-04        1.8968E-03        0.0002797;
1.49         0.00224         0.89895        0.09881         0        0        0        6.4058E-04        2.0193E-03        0.0002921;
2.70         0.00531  0.81544        0.17925         0        0        0        1.3040E-03        2.3203E-03        0.0003679;
1.02         0.00254         0.92936        0.06810         0        0        0        2.0611E-04        1.7761E-03        0.0003612;
0.82         0.00273         0.92918        0.06809         0        0        0        4.6464E-04        1.6084E-03        0.0001887;
0.97         0.00213         0.91722        0.08065         0        0        0        7.9002E-04        1.3764E-03        0.0001489;
1.19         0.00379         0.89756        0.09865         0        0        0        9.7162E-04        1.7297E-03        0.0002101;
2.16         0.00663         0.81436        0.17902         0        0        0        1.7438E-03        2.1190E-03        0.0003488
];   
                 
% 使用函数fmincon()进行参数估计
[k,fval,flag] = fmincon(@ObjFunc4Fmincon,k0,[],[],[],[],lb,ub,[],[]);
fprintf('\n使用函数fmincon()估计得到的参数值为:\n')
fprintf('\tk1(KH) = %.4f\n',k(1))
fprintf('\tk2(KDMM) = %.4f\n',k(2))
fprintf('\tk3(KMe) = %.4f\n',k(3))
fprintf('\tk4(KHPM) = %.4f\n',k(4))
fprintf('\tk5(KPDO) = %.4f\n',k(5))
fprintf('\tk6(k1) = %.4f\n',k(6))
fprintf('\tk7(k2) = %.4f\n',k(7))
fprintf('\tk8(k3) = %.4f\n',k(8))
fprintf('  The sum of the squares is: %.1e\n\n',fval)
k_fmincon = k;


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

% 以函数fmincon()估计得到的结果为初值,使用函数lsqnonlin()进行参数估计
k0 = k_fmincon;
[k,resnorm,residual,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@ObjFunc4LNL,k0,lb,ub,[]);      
ci = nlparci(k,residual,jacobian);
fprintf('\n\n以fmincon()的结果为初值,使用函数lsqnonlin()估计得到的参数值为:\n')
Output
function f = ObjFunc4Fmincon(k)
%  t     H2in   DMMin   Mein    HPMin   PDOin   NPAin   HPMout   PDOout NPAout
data=...
[2.05         0.00258         0.92932        0.06810         0        0        0        3.1360E-05        1.1642E-03        0.0011365;
1.37         0.00155         0.93029        0.06817         0        0        0        7.8438E-05        1.3477E-03        0.0005733;
1.62         0.00173         0.91758        0.08068         0        0        0        1.0444E-04        1.7271E-03        0.0004754;
1.98         0.00187         0.89928        0.09884         0        0        0        2.8942E-04        2.3631E-03        0.0004436;
1.21         0.00158         0.91772        0.08070         0        0        0        4.1373E-04        1.8968E-03        0.0002797;
1.49         0.00224         0.89895        0.09881         0        0        0        6.4058E-04        2.0193E-03        0.0002921;
2.70         0.00531  0.81544        0.17925         0        0        0        1.3040E-03        2.3203E-03        0.0003679;
1.02         0.00254         0.92936        0.06810         0        0        0        2.0611E-04        1.7761E-03        0.0003612;
0.82         0.00273         0.92918        0.06809         0        0        0        4.6464E-04        1.6084E-03        0.0001887;
0.97         0.00213         0.91722        0.08065         0        0        0        7.9002E-04        1.3764E-03        0.0001489;
1.19         0.00379         0.89756        0.09865         0        0        0        9.7162E-04        1.7297E-03        0.0002101;
2.16         0.00663         0.81436        0.17902         0        0        0        1.7438E-03        2.1190E-03        0.0003488
];   
yexp = [data(:,8),data(:,9),data(:,10)];                  
for i=1:12
    [t x] = ode45(@KineticEqs,[0,data(:,1)],[data(:,2),data(:,3),data(:,4),data(:,5),data(:,6),data(:,7)],[],k);
y(:,1:3) = x(:,4:6)
f = sum((y(:,1)-yexp(:,1)).^2+(y(:,2)-yexp(:,2)).^2+(y(:,3)-yexp(:,3)).^2);
end
% ------------------------------------------------------------------
function f = ObjFunc4LNL(k)
%  t     H2in   DMMin   Mein    HPMin   PDOin   NPAin   HPMout   PDOout NPAout
data=...
[2.05         0.00258         0.92932        0.06810         0        0        0        3.1360E-05        1.1642E-03        0.0011365;
1.37         0.00155         0.93029        0.06817         0        0        0        7.8438E-05        1.3477E-03        0.0005733;
1.62         0.00173         0.91758        0.08068         0        0        0        1.0444E-04        1.7271E-03        0.0004754;
1.98         0.00187         0.89928        0.09884         0        0        0        2.8942E-04        2.3631E-03        0.0004436;
1.21         0.00158         0.91772        0.08070         0        0        0        4.1373E-04        1.8968E-03        0.0002797;
1.49         0.00224         0.89895        0.09881         0        0        0        6.4058E-04        2.0193E-03        0.0002921;
2.70         0.00531  0.81544        0.17925         0        0        0        1.3040E-03        2.3203E-03        0.0003679;
1.02         0.00254         0.92936        0.06810         0        0        0        2.0611E-04        1.7761E-03        0.0003612;
0.82         0.00273         0.92918        0.06809         0        0        0        4.6464E-04        1.6084E-03        0.0001887;
0.97         0.00213         0.91722        0.08065         0        0        0        7.9002E-04        1.3764E-03        0.0001489;
1.19         0.00379         0.89756        0.09865         0        0        0        9.7162E-04        1.7297E-03        0.0002101;
2.16         0.00663         0.81436        0.17902         0        0        0        1.7438E-03        2.1190E-03        0.0003488
];   
for i=1:12  
    yexp = [data(:,8),data(:,9),data(:,10)];   
[t x] = ode45(@KineticEqs,[0,data(:,1)],[data(:,2),data(:,3),data(:,4),data(:,5),data(:,6),data(:,7)],[],k);
y(:,1:3) = x(:,4:6);
f1 = y(:,1) - yexp(:,1);
f2 = y(:,2) - yexp(:,2);
f3 = y(:,3) - yexp(:,3);
f = [f1; f2; f3];
end

% ------------------------------------------------------------------
function dxdt = KineticEqs(t,x,k)
% 动力学方程,氢气与DMO均解离吸附,表面反应为控制步骤。
r1 = k(6).*((k(1).*x(1).*k(2).*x(2)).^0.5)./...
   (1+2.*(k(2).*x(2)).^0.5+2.*(k(4).*x(4)).^0.5+(k(1).*x(1)).^0.5+k(3).*x(3)+k(5).*x(5)).^2;

r2 = k(7).*((k(1).*x(1).*k(4).*x(4)).^0.5)./...
   (1+2.*(k(2).*x(2)).^0.5+2.*(k(4).*x(4)).^0.5+(k(1).*x(1)).^0.5+k(3).*x(3)+k(5).*x(5)).^2;

r3 = k(8).*k(5).*k(2).*x(5).*x(2)./...
(1+2.*(k(1).*x(1)).^0.5+2.*(k(4).*x(4)).^0.5+(k(2).*x(2)).^0.5+k(3).*x(3)+k(5).*x(5)).^2;
   
dxdt=...
    [-2.*r1-2.*r2-r3      % H2
    -r1                   % DMM
    r1+r2                 % ME
    r1-r2                 % HPM
    r2-r3                 % PDO
    r3                    % NPA
       ];
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 zhaoshazhu 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料工程281还有调剂机会吗 +24 xaw. 2026-04-11 24/1200 2026-04-12 10:32 by 猪会飞
[考研] 电子信息270求调剂 +15 terminal469 2026-04-07 15/750 2026-04-12 09:44 by 逆水乘风
[考研] 280求调剂 +13 wzzz王 2026-04-09 13/650 2026-04-12 00:31 by 勇攀高峰0126
[考研] 22专硕求调剂 +6 haoyun上岸 2026-04-11 8/400 2026-04-11 23:21 by labixiaoqiao
[教师之家] 请问地理、遥感方面,可以做哪些横向项目啊,纵向完不成考核啊 +3 锦衣卫寒战 2026-04-07 5/250 2026-04-11 20:51 by 豫椒
[考研] 266求调剂,一志愿哈工程电子信息,本科获多项国奖和省奖 +8 lumine1 2026-04-06 8/400 2026-04-11 18:35 by 逆水乘风
[考研] 269求调剂 +11 啊啊我我 2026-04-07 11/550 2026-04-11 16:45 by vgtyfty
[考研] 一志愿北理工298英一数二已上岸,感谢各位老师 +14 Reframe 2026-04-10 16/800 2026-04-10 23:07 by caotw2020
[考研] 江苏大学 工科调剂 捡漏 +3 Evan_Liu 2026-04-09 5/250 2026-04-10 10:22 by Evan_Liu
[考研] 085600材料与化工301分求调剂院校 +33 刺痛jk 2026-04-06 34/1700 2026-04-09 18:31 by hy861222
[考研] 本科郑州大学,一志愿华东师范大学282求调剂 +23 熊哥xtk 2026-04-07 26/1300 2026-04-09 17:17 by 18446523
[考研] 一志愿武理车辆 281 求调剂 +5 上岸研究生. 2026-04-07 5/250 2026-04-09 15:56 by only周
[考研] 1U盾记得记得就 +9 sanjin020722 2026-04-08 10/500 2026-04-09 14:11 by 诗与自由
[考研] 求调剂 +3 猪肉墩粉条cc 2026-04-08 4/200 2026-04-09 10:05 by 猪肉墩粉条cc
[考研] 334求调剂 +16 Riot2025 2026-04-08 17/850 2026-04-09 09:28 by wdyheheeh
[考博] 材料方向考博,求推荐 +3 言语aaa 2026-04-05 4/200 2026-04-08 22:22 by nxgogo
[考研] 求调剂 +11 wwwwabcde 2026-04-07 11/550 2026-04-07 23:16 by JourneyLucky
[考研] 085602调剂 初试总分335 +3 19123253302 2026-04-06 3/150 2026-04-07 18:00 by jp9609
[考研] 081200-11408-367学硕求调剂 +4 1_2_3111 2026-04-06 4/200 2026-04-07 08:13 by jp9609
[考研] 085405软件工程301分求调剂,专硕可跨专业,四六级已过 +3 静静想想 2026-04-05 3/150 2026-04-06 15:23 by nepu_uu
信息提示
请填处理意见