24小时热门版块排行榜    

查看: 916  |  回复: 2

apollosun9283

金虫 (小有名气)

剑桥公爵

[求助] 常微分方程组初值问题的参数确定

方程如附件的图1和图2所示。

--------------------定义方程组---------------------------------------------------
function dydt=tangbin(t,y)
global k1 k2 k3 k4 k5 k6 k7
f1=3*k1*y(1)-k2*y(1)*y(2)-k3*y(1)*y(3)-k4*y(1)*y(4)-...
    k5*y(1)*y(5)-k6*y(1)*y(6)-k7*y(1);
f2=-1/3*k2*76/90*y(1)*y(2);
f3=1/3*k2*106/90*y(1)*y(2)-1/3*k3*106/90*y(1)*y(3);
f4=1/3*k3*136/90*y(1)*y(3)-1/3*k4*136/90*y(1)*y(4);
f5=1/3*k4*166/90*y(1)*y(4)-1/3*k5*166/90*y(1)*y(5);
f6=1/3*k5*196/90*y(1)*y(5)-1/3*k6*196/90*y(1)*y(6);
f7=1/3*k6*226/90*y(1)*y(6)-1/3*k7*226/90*y(1);
f8=1/3*k7*256/90*y(1);
dydt=[f1;f2;f3;f4;f5;f6;f7;f8];

--------------------------以k值的猜测值计算y-----------------------------
clear all;clc
global k1 k2 k3 k4 k5 k6 k7
k1=5;
k2=900;
k3=500;
k4=500;
k5=500;
k6=700;
k7=3;
y0=[0.25 0.75 0 0 0 0 0 0];
[t,y]=ode45(@tangbin,[1/30 1/24 1/18 1/12],y0);
yexp=0.01*[2.21 62.89 19.04 6.86 2.34 0.80 0.27 0.02;...
    1.82 59.76 20.23 8.07 2.97 1.02 0.33 0.05;...
    1.15 55.64 22.27 9.48 3.73 1.34 0.47 0.12;
    1.06 55.13 21.85 9.69 3.99 1.59 0.62 0.22];
s=sum(sum((y-yexp).^2))

-------------------------------------------------------------------------------
现在我遇到的问题是,下一步如何调整k值,使得s=sum(sum((y-yexp).^2))尽可能的小。我设想过给k构建一个循环语句来调整k,但是如何调整,没有思路。

请高手帮帮忙!

1.jpg



2.jpg
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

倚楼听风雨,淡看江湖路
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

gyctju

金虫 (正式写手)

直接手动求极值不行吗?应该不是很复杂啊?
2楼2012-10-12 23:10:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

月只蓝

主管区长 (职业作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ...
感谢参与,应助指数 +1
apollosun9283: 金币+150, ★★★★★最佳答案, 十分感谢! 2012-10-13 09:06:40
xiegangmai: 金币+3 2012-10-14 08:23:29
参考实用计算机模拟书,程序如下,做出来问题,至于效果的话,请楼主调一下k初值:

function canshinihe
clear all;clc
tspan=[0 1/30 1/24 1/18 1/12];
y0=[0.25;0.75;0;0;0;0;0;0];
k0=[1 1 1 1 1 1 1]*0.1;
lb=[0 0 0 0 0 0 0];
ub=[1 1 1 1 1 1 1]*10^5;                                                                                
yexp=0.01*[2.21 62.89 19.04 6.86 2.34 0.80 0.27 0.02;...
    1.82 59.76 20.23 8.07 2.97 1.02 0.33 0.05;...
    1.15 55.64 22.27 9.48 3.73 1.34 0.47 0.12;
    1.06 55.13 21.85 9.69 3.99 1.59 0.62 0.22];


% 使用函数lsqnonlin()进行参数估计
[k,resnorm,residual,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@ObjFunc,k0,lb,ub,[],tspan,y0,yexp);
ci = nlparci(k,residual,jacobian);
fprintf('\n\n使用函数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('\tk3 = %.4f ± %.4f\n',k(3),ci(3,2)-k(3))
fprintf('\tk4 = %.4f ± %.4f\n',k(4),ci(4,2)-k(4))
fprintf('\tk5 = %.4f ± %.4f\n',k(5),ci(5,2)-k(5))
fprintf('\tk6 = %.4f ± %.4f\n',k(6),ci(6,2)-k(6))
fprintf('\tk7 = %.4f ± %.4f\n',k(7),ci(7,2)-k(7))
fprintf('  The sum of the squares is: %.1e\n\n',resnorm)

%---------------------------------------------------------
function f = ObjFunc(k,tspan,y0,yexp)           % 目标函数
[t Xsim] = ode45(@KineticsEqs,tspan,y0,[],k);   
ysim(:,1) = Xsim(2:end,1);
ysim(:,2) = Xsim(2:end,2);
ysim(:,3) = Xsim(2:end,3);
ysim(:,4) = Xsim(2:end,4);
ysim(:,5) = Xsim(2:end,5);
ysim(:,6) = Xsim(2:end,6);
ysim(:,7) = Xsim(2:end,7);
ysim(:,8) = Xsim(2:end,8);
f =[ysim(:,1)-yexp(:,1); ysim(:,2)-yexp(:,2); ysim(:,3)-yexp(:,3);...
   ysim(:,4)-yexp(:,4); ysim(:,5)-yexp(:,5);  ysim(:,6)-yexp(:,6);...
     ysim(:,7)-yexp(:,7); ysim(:,8)-yexp(:,8)];
%----------------------------------------------------------

function dydt = KineticsEqs(t,y,k)
f1=3*k(1)*y(1)-k(2)*y(1)*y(2)-k(3)*y(1)*y(3)-k(4)*y(1)*y(4)-...
    k(5)*y(1)*y(5)-k(6)*y(1)*y(6)-k(7)*y(1);
f2=-1/3*k(2)*76/90*y(1)*y(2);
f3=1/3*k(2)*106/90*y(1)*y(2)-1/3*k(3)*106/90*y(1)*y(3);
f4=1/3*k(3)*136/90*y(1)*y(3)-1/3*k(4)*136/90*y(1)*y(4);
f5=1/3*k(4)*166/90*y(1)*y(4)-1/3*k(5)*166/90*y(1)*y(5);
f6=1/3*k(5)*196/90*y(1)*y(5)-1/3*k(6)*196/90*y(1)*y(6);
f7=1/3*k(6)*226/90*y(1)*y(6)-1/3*k(7)*226/90*y(1);
f8=1/3*k(7)*256/90*y(1);
dydt=[f1;f2;f3;f4;f5;f6;f7;f8];
MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
3楼2012-10-13 07:13:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 apollosun9283 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料工程专硕 348分求调剂 +3 冬辞. 2026-03-17 5/250 2026-03-21 18:47 by 学员8dgXkO
[考研] 材料学硕333求调剂 +3 北道巷 2026-03-18 3/150 2026-03-21 18:17 by 学员8dgXkO
[考研] 302求调剂 +12 呼呼呼。。。。 2026-03-17 12/600 2026-03-21 17:29 by ColorlessPI
[考研] 298求调剂 +4 上岸6666@ 2026-03-20 4/200 2026-03-21 17:14 by 学员8dgXkO
[考研] 299求调剂 +5 shxchem 2026-03-20 7/350 2026-03-21 17:09 by ColorlessPI
[考研] 生物学一志愿985,分数349求调剂 +3 zxts12 2026-03-21 3/150 2026-03-21 16:34 by 33来了真来了
[考研] 化学求调剂 +4 临泽境llllll 2026-03-17 5/250 2026-03-21 02:23 by JourneyLucky
[考研] 材料专硕英一数二306 +7 z1z2z3879 2026-03-18 7/350 2026-03-20 23:48 by JourneyLucky
[考研] 一志愿南京理工大学085701资源与环境302分求调剂 +4 葵梓卫队 2026-03-18 6/300 2026-03-20 23:02 by JourneyLucky
[考研] 323求调剂 +3 洼小桶 2026-03-18 3/150 2026-03-20 22:54 by JourneyLucky
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +4 @taotao 2026-03-19 4/200 2026-03-20 22:14 by JourneyLucky
[考研] 295复试调剂 +8 简木ChuFront 2026-03-19 8/400 2026-03-20 20:44 by zhukairuo
[考博] 招收博士1-2人 +3 QGZDSYS 2026-03-18 3/150 2026-03-20 11:58 by 呱呱呱呱叫
[考博] 申博26年 +3 八6八68 2026-03-19 3/150 2026-03-19 19:43 by nxgogo
[考研] 0703化学调剂 +5 pupcoco 2026-03-17 8/400 2026-03-19 13:58 by houyaoxu
[考研] 收复试调剂生 +4 雨后秋荷 2026-03-18 4/200 2026-03-18 14:16 by elevennnne
[考研] 326求调剂 +5 上岸的小葡 2026-03-15 6/300 2026-03-17 17:26 by ruiyingmiao
[考研] 一志愿南京大学,080500材料科学与工程,调剂 +4 Jy? 2026-03-16 4/200 2026-03-17 11:02 by gaoqiong
[考研] 11408 一志愿西电,277分求调剂 +3 zhouzhen654 2026-03-16 3/150 2026-03-17 07:03 by laoshidan
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
信息提示
请填处理意见