24小时热门版块排行榜    

查看: 1619  |  回复: 1

_romantic_镇

木虫 (著名写手)

[求助] 初学者求助,matlab模仿程序 已有1人参与

function KineticsEst5
% 动力学ODE方程模型的参数估计

clear all
clc

k0 = [0  0  0  0];         % 参数初值
lb = [ -inf  -inf  -inf  -inf ];                   % 参数下限
ub = [+inf  +inf  +inf  +inf ];    % 参数上限
x0 = [8.5 28.8 27.6];
tspan=[0 0.222 0.333 0.444];
yexp =  [8.5000   28.8000   27.6000
    4.8000   23.2000   35.3000
    4.2000   21.6000   36.5000
    4.0000   21.2000   37.3000];                 % yexp: 实验数据[x1        x2 x3]

% 使用函数fmincon()进行参数估计
[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('  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,[],x0,yexp);      
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,[],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.44];
[t x] = ode45(@KineticEqs,tspan,x0,[],k);   
y(:,1:3) = x(:,1:3);
f = sum((y(:,1)-yexp(:,1)).^2) + sum((y(:,2)-yexp(:,2)).^2)   ...
    + sum((y(:,3)-yexp(:,3)).^2) ;

% 以函数fmincon()估计得到的结果为初值,使用函数lsqnonlin()进行参数估计
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 = ObjFunc4LNL(k,x0,yexp)
tspan = [0.00 : 0.01 : 0.44];
[t x] = ode45(@KineticEqs,tspan,x0,[],k);   
y(:,1:3) = x(:,1:3);
f1 = y(:,1) - yexp(:,1);
f2 = y(:,2) - yexp(:,2);
f3 = y(:,3) - yexp(:,3);
f = [f1; f2; f3];

% ------------------------------------------------------------------
function dxdt = KineticEqs(t,x,k)
dxdt =  ...
[ (k(1)*x(2)- k(1)*x(1))
   (k(1)*x(2)+(k(3)-k(2)-k(4))*x(3))
   (k(3)*x(2)-k(4)*x(3))
   ];
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzlhm

至尊木虫 (著名写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
_romantic_镇: 金币+50, 有帮助 2022-03-15 11:07:58
程序中的问题:
1、tspan = [0.00 : 0.01 : 0.44]与tspan=[0 0.222 0.333 0.444]没有对应
2、f = sum((y(:,1)-yexp(:,1)).^2) + sum((y(:,2)-yexp(:,2)).^2)  + sum((y(:,3)-yexp(:,3)).^2)  后面的代码是多余的,计算的结果不使用
执行结果:

使用函数fmincon()估计得到的参数值为:
        k1 = -0.6403
        k2 = 1.8125
        k3 = 3.6968
        k4 = 1.9950
The sum of the squares is: 4.0
QQ:2120156492
2楼2021-12-27 22:26:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 _romantic_镇 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 环境工程学硕288求助调剂 +5 多吃亿口芝士 2026-03-02 5/250 2026-03-03 14:38 by wang_dand
[考研] 材料学硕318求调剂 +11 February_Feb 2026-03-01 11/550 2026-03-03 14:24 by NUAAZXWS
[基金申请] 没有青基直接申请面上,感觉自己疯了 +4 kevin63t 2026-03-02 5/250 2026-03-03 13:39 by 443933501
[考研] 26考研报考西工大材料308分求调剂 +4 weizhong123 2026-03-01 5/250 2026-03-03 12:22 by weizhong123
[考研] 材料325求调剂 30+3 mariusuki 2026-03-02 7/350 2026-03-03 11:14 by EBSD
[基金申请] 成果系统访问量大,请15分钟后再尝试。由此给您造成的不便,敬请谅解。 +8 xhuama 2026-03-02 9/450 2026-03-03 08:13 by kudofaye
[考研] 化工京区271求调剂 +7 11ing 2026-03-02 7/350 2026-03-03 07:30 by 利好利好.
[考研] 0854复试调剂 276 +5 wmm9 2026-03-01 7/350 2026-03-03 02:49 by xiadaiyang
[考研] 0856调剂 +10 刘梦微 2026-02-28 10/500 2026-03-02 23:42 by hcy618
[考研] 0856材料与化工,270求调剂 +11 YXCT 2026-03-01 13/650 2026-03-02 21:38 by sunny81
[考研] 0856材料调剂 +5 沿岸有贝壳OUC 2026-03-02 5/250 2026-03-02 20:31 by hypershenger
[考研] 0856材料求调剂 +12 hyf hyf hyf 2026-02-28 13/650 2026-03-02 20:19 by hypershenger
[考研] 0856求调剂285 +11 吕仔龙 2026-02-28 11/550 2026-03-02 20:15 by hypershenger
[考研] 085600材料工程一志愿中科大总分312求调剂 +9 吃宵夜1 2026-02-28 11/550 2026-03-02 20:14 by hypershenger
[考研] 化学,材料,环境类求调剂 +7 考研版棒棒 2026-03-02 7/350 2026-03-02 19:56 by hypershenger
[考研] 一志愿山东大学材料与化工325求调剂 +5 半截的诗0927 2026-03-02 5/250 2026-03-02 18:37 by 明亮9527
[考研] 274求调剂 +3 cgyzqwn 2026-03-01 7/350 2026-03-02 10:38 by lature00
[基金申请] 成果系统访问量大,请一小时后再尝试。---NSFC啥时候好哦,已经两天这样了 +4 NSFC2026我来了 2026-02-28 4/200 2026-03-01 22:37 by 铁门栓
[考研] 化工299分求调剂 一志愿985落榜 +5 嘻嘻(*^ω^*) 2026-03-01 5/250 2026-03-01 19:47 by 无际的草原
[考研] 328求调剂 +3 aaadim 2026-03-01 5/250 2026-03-01 17:29 by njzyff
信息提示
请填处理意见