24小时热门版块排行榜    

查看: 921  |  回复: 3
【悬赏金币】回答本帖问题,作者修竹好衰将赠送您 20 个金币

修竹好衰

新虫 (初入文坛)

[求助] 初学用MATLAB求解动力学模型,但是在非线性二乘法处出现问题 ,麻烦各位大神帮忙看看 已有2人参与

出现的问题是:
错误使用 lsqncommon (line 64)
The Levenberg-Marquardt algorithm does not handle bound constraints and the
trust-region-reflective algorithm requires at least as many equations as variables; aborting.

出错 lsqnonlin (line 262)
   lsqncommon(funfcn,xCurrent,lb,ub,options,defaultopt,optimgetFlag,caller,...

出错 kinetic (line 16)
lsqnonlin(@fun,k0,lb,ub,[],yexp);

其中反应数据是引用文件:‘reaction.xls’中每7行为一个反应温度下的各个时间点数据,总共3个温度下的数据,共计21行,已在后面图片里面显示

程序:
clc
clear all;
global a b
tspan=[0 1 3 5 7 9 11]; %各个反应时间点,0h,1h,3h……
yexp=xlsread('reaction.xls') %y的赋值从reaction这个excel文件中调取
k0=[2*10^8 60000 6.75*10^10 72000 3*10^11 90000]; %每个反应速率常数k所对应的A、E,总计6个参数初值设定(正反应、逆反应、副反应)
lb=[0 0 0 0 0 0];
ub=[+inf +inf +inf +inf +inf +inf];
[k,resnorm,residual,exitflag,output,lambda,jacobian]=lsqnonlin(@fun,k0,lb,ub,[],yexp);
%=====================================================================================
function f=fun(k,yexp) %这个就是拟合的目标函数,得到对应最合适的k
f=[];
for i=1:3 %对应三个温度下的数据,
tspan=[0 1 3 5 7 9 11];
a=7*(i-1)+1;
x0=yexp(a,;
[t,x]=ode45(@func,tspan,x0,[],k,i);
d=a+6;
yc1=x(:,1);
yc2=x(:,2);
yc3=x(:,3);
yc4=x(:,4);
f11=yexp(a:d,1)-yc1;
f12=yexp(a:d,2)-yc2;
f13=yexp(a:d,3)-yc3;
f14=yexp(a:d,4)-yc4;
ff=[f11 f12 f13 f14];
f=[f:ff];
end
%=====================================================================================
function dxdt=func(t,x,k,i)
switch i
         case 1
         m=0.6;
         V=0.2431;
         T=303.15;
         case 2
         m=0.6;
         V=0.2448;
         T=313.15;
         case 3
         m=0.6;
         V=0.2491;
         T=323.15;
end
r2=-(k(1)*exp(-k(2)/8.314/T)*x(1)/V*x(2)/V-k(3)*exp(-k(4)/8.314/T)*x(3)/V);
r3=-r2;
r4=k(5)*exp(-k(6)/8.314/T)*x(1)/V*x(1)/V;
r1=r2-2*r4;
dxdt=[m*r1;m*r2;m*r3;m*r4]; %因为这里r的单位是mol/(g min L)所以需要乘以质量
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
微分方程拟合问题,Matlab得不到理想结果得话,换1stOpt试试,更容易实现,效果也更好

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

2楼2022-03-05 19:23:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

修竹好衰

新虫 (初入文坛)

送红花一朵
引用回帖:
2楼: Originally posted by dingd at 2022-03-05 19:23:00
微分方程拟合问题,Matlab得不到理想结果得话,换1stOpt试试,更容易实现,效果也更好

非常感谢,之后会去试试1stopt,主要是现在这个程序是别人网上分享的,想照写下来试试能不能运行得到与他相同的结果,然后程序运行出现的这个错误不知道怎么改,想问问
3楼2022-03-06 13:56:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzlhm

至尊木虫 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
你的问题,可能出现在初值设定上不合理。
QQ:2120156492
4楼2022-03-06 20:23:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 修竹好衰 的主题更新
不应助 确定回帖应助 (注意:应助才可能被奖励,但不允许灌水,必须填写15个字符以上)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] A区一本交叉课题组,低分调剂,招收机械电子信息通信等交叉方向 +41 lisimayy 2026-03-04 54/2700 2026-03-08 01:10 by 求上岸 求上岸
[考研] 求调剂,一志愿华中科大0702,数一英一,293 +3 小罗露一二 2026-03-07 3/150 2026-03-07 23:58 by 1710470214
[考研] 288求调剂085600材料与化工 +10 Daunrin 2026-03-07 12/600 2026-03-07 22:38 by Leeding1356
[考研] 材料工程专硕调剂自荐信,初试323 +4 李白26 2026-03-07 4/200 2026-03-07 21:59 by 星空星月
[考研] 材料化工求调剂 +6 博斯特525 2026-03-06 7/350 2026-03-07 19:17 by houyaoxu
[考研] 材料专硕调剂 +5 慕辰123 2026-03-05 8/400 2026-03-07 15:54 by xuesongli73
[考研] 一志愿211,0860总分286食品工程专业求调剂 +6 林林Winnie 2026-03-05 6/300 2026-03-06 20:06 by 我想上研究生.
[考研] 材料学硕318求调剂 +13 February_Feb 2026-03-01 13/650 2026-03-06 15:30 by GGOND
[考研] 08工科求调剂 +3 隆LLL 2026-03-06 4/200 2026-03-06 15:26 by 隆LLL
[考研] 不限学校专业的调剂同学看过来 +5 啊摆啊摆 2026-03-05 9/450 2026-03-06 12:06 by 啊摆啊摆
[考研] 080500材料科学与工程 +13 202114020319 2026-03-03 13/650 2026-03-06 00:29 by wutongshun
[考研] 材料调剂 +5 ws 上岸鸭 2026-03-05 5/250 2026-03-05 20:06 by houyaoxu
[考研] 调剂材料学硕 +6 词凝Y 2026-03-02 6/300 2026-03-05 07:10 by 昆工985
[考研] 264求调剂 +8 26调剂 2026-03-03 8/400 2026-03-04 20:50 by 一切OK
[考研] 307求调剂 +4 xuyuan111 2026-03-04 5/250 2026-03-04 20:39 by kakakapanpan
[考研] 281求调剂 +3 Y?l?h 2026-03-04 3/150 2026-03-04 10:51 by 汪!?!
[考研] 计算机学硕 分数285求调剂 +4 glwshine 2026-03-02 5/250 2026-03-03 14:27 by king呀
[考研] 材料工程专硕283求调剂 5+8 ,!? 2026-03-02 10/500 2026-03-03 12:01 by EBSD
[考研] 【2026 硕士调剂】课题组 招收调剂生 +3 考研版棒棒 2026-03-02 5/250 2026-03-03 01:45 by kkky.
[考研] 261求调剂 +3 陆lh 2026-03-01 3/150 2026-03-02 19:32 by zhukairuo
信息提示
请填处理意见