24小时热门版块排行榜    

Znn3bq.jpeg
汕头大学海洋科学接受调剂
查看: 2132  |  回复: 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的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 290调剂生物0860 +36 哇哈哈,。 2026-04-11 42/2100 2026-04-15 13:13 by 西北望—风沙
[考研] 人工智能320调剂08工类还有机会吗 +18 振—TZ 2026-04-10 19/950 2026-04-14 10:34 by screening
[考研] 机械工程313分找工科调剂 +4 双一流本科机械 2026-04-08 4/200 2026-04-14 07:32 by Abskk
[考研] 一志愿华工085600 331分 +7 天下ww 2026-04-09 7/350 2026-04-13 09:01 by lhj2009
[考研] 291求调剂 +8 关忆北. 2026-04-11 8/400 2026-04-12 09:32 by 逆水乘风
[考研] 求调剂,一志愿材料科学与工程985,365分, +8 材化李可 2026-04-11 10/500 2026-04-12 08:42 by 852137818
[考研] 调剂 +5 文道星台 2026-04-11 5/250 2026-04-11 15:01 by 凯凯要变帅
[考研] 本人女孩 +7 吼吼, 2026-04-10 9/450 2026-04-11 14:45 by ACS Nano——
[考研] 085410-273求调剂 +6 X1999 2026-04-10 6/300 2026-04-11 10:32 by Delta2012
[考研] 288求调剂 +15 代fish 2026-04-09 16/800 2026-04-11 10:26 by wwj2530616
[考研] 293求调剂 +6 勇远库爱314 2026-04-08 6/300 2026-04-11 10:08 by zhq0425
[考研] 22408 352分求调剂0854类 +4 努力的夏末 2026-04-09 4/200 2026-04-11 09:57 by zhq0425
[考研] 22408调剂求助 +7 毂12 2026-04-09 9/450 2026-04-11 09:23 by 哦哦123
[考研] 342电子信息专硕求调剂 +9 你让我怎么荔枝 2026-04-10 10/500 2026-04-11 08:33 by zhq0425
[考研] 263能源动力专硕求调剂 +4 加大号饭盒袋 2026-04-10 4/200 2026-04-10 20:52 by gong120082
[考研] 计算机类求调剂,22408-274分 +7 上岸de小虫 2026-04-09 8/400 2026-04-10 19:56 by fxue1114
[考研] 一志愿京区985,085401电子信息,本科电子信息 +3 阳光开朗的男孩 2026-04-10 3/150 2026-04-10 16:29 by sophia_93
[考研] 085800 能源动力求调剂 +6 阿biu啊啊啊啊啊 2026-04-10 6/300 2026-04-10 15:03 by hemengdong
[考研] 求调剂 材料与工程 324分 专硕 +19 翩翩一书生 2026-04-10 21/1050 2026-04-10 11:41 by wp06
[考研] 085801 总分275 本科新能源 求调剂 +8 bradoner 2026-04-08 9/450 2026-04-09 13:43 by only周
信息提示
请填处理意见