24小时热门版块排行榜    

查看: 2084  |  回复: 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的回帖

雾隐村的白

新虫 (初入文坛)

送红花一朵
引用回帖:
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的回帖
查看全部 6 个回答

独孤神宇

版主 (知名作家)

【答案】应助回帖

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

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

数值计算
2楼2019-12-16 10:21:29
已阅   回复此楼   关注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的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 化学工程085602 305分求调剂 +10 RichLi_ 2026-03-25 10/500 2026-03-26 02:17 by BruceLiu320
[考研] 299求调剂 +4 15188958825 2026-03-25 4/200 2026-03-25 22:56 by 418490947
[考研] 321求调剂 +3 璞玉~~ 2026-03-25 3/150 2026-03-25 19:07 by Zhanglab-TJU
[考研] 求b区院校调剂 +4 周56 2026-03-24 5/250 2026-03-25 17:12 by yishunmin
[考研] 【2026考研调剂】制药工程 284分 求相关专业调剂名额 +4 袁奂奂 2026-03-25 8/400 2026-03-25 14:32 by lbsjt
[考研] 0854电子信息求调剂 324 +4 Promise-jyl 2026-03-23 4/200 2026-03-25 11:36 by Sugarlight
[考研] 材料调剂 +3 iwinso 2026-03-23 3/150 2026-03-25 11:29 by greychen00
[考研] 299求调剂 +7 shxchem 2026-03-20 9/450 2026-03-25 10:41 by lbsjt
[考研] 286求调剂 +11 Faune 2026-03-21 11/550 2026-03-25 10:11 by 雾散后相遇lc
[考研] 求调剂 一志愿 本科 北科大 化学 343 +4 13831862839 2026-03-24 5/250 2026-03-25 09:47 by 无际的草原
[考研] 318求调剂 +5 plum李子 2026-03-21 8/400 2026-03-25 09:26 by aa331100
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +6 @taotao 2026-03-19 6/300 2026-03-25 08:37 by 木托莫露露
[考研] 300分,材料,求调剂,英一数二 +5 超赞的 2026-03-24 5/250 2026-03-24 21:07 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
[考研] 324求调剂 +6 lucky呀呀呀鸭 2026-03-20 6/300 2026-03-22 16:01 by ColorlessPI
[考研] 一志愿华中科技大学071000,求调剂 +4 沿岸有贝壳6 2026-03-21 4/200 2026-03-22 07:21 by ilovexiaobin
[考研] 085600材料与化工306 +4 z1z2z3879 2026-03-21 4/200 2026-03-21 23:44 by ms629
[考研] 求调剂 +3 13341 2026-03-20 3/150 2026-03-21 18:28 by 学员8dgXkO
[考研] 材料考研调剂 +3 xwt。 2026-03-19 3/150 2026-03-19 11:22 by w沐阳w
信息提示
请填处理意见