24小时热门版块排行榜    

查看: 2086  |  回复: 5

雾隐村的白

新虫 (初入文坛)

[求助] matlab模拟微分方程参数求助各位大佬 已有1人参与

反应动力学方程:dC/dt=-k1*c*(2.413+C)+k2*(4.826-C)^2;
t=[0 15 30 45 60 75 90 120];
C=[4.826 4.206045728 3.081681077 2.582976758 2.368099268 2.296997119 2.259547446 2.221752483];
求解参数 k1,k2;
1stopt没有软件条件,所以只能寄希望于matlab。
请教各位大佬matlab代码怎么写,感激不尽!!!
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

独孤神宇

版主 (知名作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...
感谢参与,应助指数 +1
雾隐村的白: 金币+100, ★★★很有帮助 2019-12-16 13:21:59

» 本帖已获得的红花(最新10朵)

数值计算
2楼2019-12-16 10:21:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

雾隐村的白

新虫 (初入文坛)

送红花一朵
引用回帖:
2楼: Originally posted by 独孤神宇 at 2019-12-16 10:21:29
http://blog.sina.com.cn/s/blog_c0cb8ce60102ysqt.html

模仿代码修改如下:
function ODEfunction
clear all;clc
format long
tspan=[0 15 30 45 60 75 90 120]; % size=1*8
yexp=[4.826 4.206045728 3.081681077 2.582976758 2.368099268 2.296997119 2.259547446 2.221752483]';   % size=8*1,已将第一个数据取出作为下面的初始值
k0=[0.002 0.003];   %猜测初值
y0=4.826;             % 初始状态
lb=[0 0 ];             % 参数下限
ub=[1 1];       % 参数上限
yy=[y0 yexp'];          % 未给定初始值,则第一行作为初始值
% 使用函数fmincon()进行参数估计
[k,fval,flag] = fmincon(@ObjFunc4Fmincon,k0,[],[],[],[],lb,ub,[],[],y0,yexp);
fprintf('\n使用函数fmincon()估计得到的参数值为:\n')
fprintf('\tk1 = %.4f\n',k(1))
fprintf('\tk2 = %.4f\n',k(2))
fprintf('The sum of the squares is: %.1e\n\n',fval)
k_fmincon = k;

% 这一步通常被省略,通过反复迭代初始值得到最优解,加上后可以降低对初始值的依赖。
% 以函数fmincon()估计得到的结果为初值,使用函数lsqnonlin()进行参数估计
% 需要指出,这种方法并非在所有场合均有效,但有时确实可以改善求解效果。

k0 = k_fmincon;
[k,resnorm,residual,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@ObjFunc4LNL,k0,lb,ub,[],y0,yexp);      
ci = nlparci(k,residual,jacobian);
fprintf('\n\n以fmincon()的结果为初值,使用函数lsqnonlin()估计得到的参数值为:\n')
fprintf('\tk1 = %.4f ± %.4f\n',k(1),ci(1,2)-k(1))
fprintf('\tk2 = %.4f ± %.4f\n',k(2),ci(2,2)-k(2))
fprintf('The sum of the squares is: %.1e\n\n',resnorm)
%---------------------------------------------------------------------
ts=0:0.5:max(tspan);          %用于计算的步长,步数可比实际数据多
[ts,ys]=ode45(@KineticEqs,ts,y0,[],k);         %微分方程求解
[ttt,XXsim] = ode45(@KineticEqs,tspan,y0,[],k); %指定点微分方程求解
y=XXsim(2:end);                    % 与实际数数据维数保持一致
R2=1-sum((yexp-y).^2)./sum((yexp-mean(y)).^2);
fprintf('\n\t决定系数R-Square = %.6f',R2);
figure
plot(ts,ys,'b',tspan,yy,'or'),legend('计算值','实验值','Location','best');
xlabel('时间');ylabel('计算结果');
% ------------------------------------------------------------------
function f = ObjFunc4Fmincon(k,x0,yexp)
tspan = 0 : 1 : 8;                          % ts=0:1:max(tspan);
[t,Xsim] = ode45(@KineticEqs,tspan,x0,[],k);  % ode45函数参数传递的调用形式
y = Xsim(2:end);                              % 对应实验数据  yexp
f = sum((y-yexp).^2);                         % 计算平方和,供fmincon调用
%---------------------------------------------------------
function f = ObjFunc4LNL(k,x0,yexp)           % lsqnonlin目标函数
tspan = 0: 1 : 8;  
[t,Xsim] = ode45(@KineticEqs,tspan,x0,[],k);
ysim = Xsim(2:end);                           % 确保维数一致
f=ysim-yexp;
%----------------------------------------------------------
function dydt = KineticEqs(t,y,k)             % 微分方程
beta(1)=k(1);
beta(2)=k(2);
dydt = -beta(1)*y*(2.413+y)+beta(2)*(4.826-y)^2;
%code end

---------------------------------------------------------------------
使用函数fmincon()估计得到的参数值为:
        k1 = 0.0203
        k2 = 0.0021
The sum of the squares is: 9.6e-01
出现了一些错误:
Error using  -
Matrix dimensions must agree.

Error in ODEfunction (line 36)
R2=1-sum((yexp-y).^2)./sum((yexp-mean(y)).^2);
也没有拟合的图表出现。

您有时间看看是什么问题么?
3楼2019-12-16 11:28:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

独孤神宇

版主 (知名作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...
雾隐村的白: 金币+100, ★★★★★最佳答案 2019-12-16 14:34:45
引用回帖:
3楼: Originally posted by 雾隐村的白 at 2019-12-16 11:28:42
模仿代码修改如下:
function ODEfunction
clear all;clc
format long
tspan=; % size=1*8
yexp=';   % size=8*1,已将第一个数据取出作为下面的初始值
k0=;   %猜测初值
y0=4.826;             % 初始状态
...

function ODEfunction_12_16
clear all;clc
format long
tspan=[0 15 30 45 60 75 90 120]; % size=1*8
yexp=[4.826 4.206045728 3.081681077 2.582976758 2.368099268 2.296997119 2.259547446 2.221752483]';   % size=8*1,已将第一个数据取出作为下面的初始值
k0=[0.002 0.003];      %猜测初值
y0=4.826;              % 初始状态
lb=[0 0 ];             % 参数下限
ub=[1 1];              % 参数上限

[k,resnorm] =lsqnonlin(@ObjFunc4LNL,k0,lb,ub,[],y0,yexp);      
fprintf('\n\n使用函数lsqnonlin()估计得到的参数值为:\n')
fprintf('\tk1 = %.4f\n',k(1))
fprintf('\tk2 = %.4f\n',k(2))
fprintf('The sum of the squares is: %.1e\n\n',resnorm)
%---------------------------------------------------------------------
ts=0:1:max(tspan);                                      %用于计算的步长,步数可比实际数据多
[ts,ys]=ode45(@KineticEqs,ts,y0,[],k);                  %微分方程求解
[ttt,XXsim] = ode45(@KineticEqs,tspan,y0,[],k);         %指定点微分方程求解
R2=1-sum((yexp-XXsim).^2)./sum((yexp-mean(XXsim)).^2);
fprintf('\n\t决定系数R^2 = %.6f',R2);
figure
plot(ts,ys,'b',tspan,yexp,'or'),legend('计算值','实验值','Location','best');
xlabel('时间');ylabel('计算结果');
% ------------------------------------------------------------------

%---------------------------------------------------------
function f = ObjFunc4LNL(k,x0,yexp)           % lsqnonlin目标函数
[t,Xsim] = ode45(@KineticEqs,tspan,x0,[],k);
f=Xsim-yexp;
end
%----------------------------------------------------------
function dydt = KineticEqs(t,y,k)             % 微分方程
beta(1)=k(1);
beta(2)=k(2);
dydt = -beta(1)*y*(2.413+y)+beta(2)*(4.826-y)^2;
end
end

» 本帖已获得的红花(最新10朵)

数值计算
4楼2019-12-16 13:51:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

雾隐村的白

新虫 (初入文坛)

送红花一朵
引用回帖:
4楼: Originally posted by 独孤神宇 at 2019-12-16 13:51:12
function ODEfunction_12_16
clear all;clc
format long
tspan=; % size=1*8
yexp=';   % size=8*1,已将第一个数据取出作为下面的初始值
k0=;      %猜测初值
y0=4.826;              % 初始状态
lb=;      ...

非常感谢!帮了大忙!!!
5楼2019-12-16 14:34:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

_romantic_镇

木虫 (著名写手)

引用回帖:
2楼: Originally posted by 独孤神宇 at 2019-12-16 10:21:29
http://blog.sina.com.cn/s/blog_c0cb8ce60102ysqt.html

看您的回复都加密了呢,怎么获取学习呢?
6楼2021-04-24 10:45:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 雾隐村的白 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 275求调剂 +3 Micky11223 2026-03-25 5/250 2026-03-25 22:32 by barlinike
[考研] 308求调剂 +5 墨墨漠 2026-03-25 5/250 2026-03-25 22:19 by 544594351
[考研] 考研一志愿苏州大学初始315(英一)求调剂 +3 sbdksD 2026-03-24 4/200 2026-03-25 18:16 by xcjcqu
[考研] 网络空间安全0839招调剂 +4 w320357296 2026-03-25 6/300 2026-03-25 17:59 by 255671
[考研] 296求调剂 +4 汪!?! 2026-03-25 7/350 2026-03-25 16:41 by 汪!?!
[考研] 0854电子信息求调剂 +7 α____ 2026-03-22 9/450 2026-03-25 13:37 by α____
[考研] 289材料与化工(085600)B区求调剂 +4 这么名字咋样 2026-03-22 5/250 2026-03-25 08:20 by mx.yue
[考研] 344求调剂 +3 desto 2026-03-24 3/150 2026-03-24 10:09 by 搏击518
[基金申请] 请教下大家 2026年国家基金申请是双盲审吗? +3 lishucheng1 2026-03-22 5/250 2026-03-24 08:22 by gltch
[考研] 276求调剂。有半年电池和半年高分子实习经历 +9 材料学257求调剂 2026-03-23 10/500 2026-03-24 07:36 by wangy0907
[考研] 284求调剂 +3 yanzhixue111 2026-03-23 6/300 2026-03-23 22:58 by pswait
[考研] 材料/农业专业,07/08开头均可,过线就行 +3 呵唔哦豁 2026-03-23 4/200 2026-03-23 22:30 by 汪!?!
[考研] 一志愿陕师大生物学071000,298分,求调剂 +3 SYA! 2026-03-23 3/150 2026-03-23 19:09 by macy2011
[考研] 333求调剂 +3 ALULU4408 2026-03-23 3/150 2026-03-23 19:04 by macy2011
[考研] 材料与化工(0856)304求B区调剂 +3 邱gl 2026-03-20 7/350 2026-03-21 19:05 by 15709483992
[考研] 0703化学调剂 +4 妮妮ninicgb 2026-03-21 4/200 2026-03-21 18:39 by 学员8dgXkO
[考研] 0703化学297求调剂 +3 Daisy☆ 2026-03-20 3/150 2026-03-21 17:45 by ColorlessPI
[考研] 085601调剂 358分 +3 zzzzggh 2026-03-20 4/200 2026-03-21 10:21 by luoyongfeng
[考研] 中南大学化学学硕337求调剂 +3 niko- 2026-03-19 6/300 2026-03-20 21:58 by luoyongfeng
[考研] 招收调剂硕士 +4 lidianxing 2026-03-19 12/600 2026-03-20 12:25 by lidianxing
信息提示
请填处理意见