24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 953  |  回复: 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个字符以上)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 285求调剂 +9 哦呦呼o 2026-04-04 9/450 2026-04-04 23:38 by lqwchd
[考研] 考研调剂 +10 小sun要好运 2026-04-04 10/500 2026-04-04 23:14 by lqwchd
[考研] 材料334求调剂 +15 Eecho# 2026-04-03 15/750 2026-04-04 23:05 by 无际的草原
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +11 努力奋斗112 2026-04-04 11/550 2026-04-04 20:51 by 蓝云思雨
[考研] 一志愿上海大学生物学346 +3 上海大学346调剂 2026-04-03 3/150 2026-04-04 20:20 by dongzh2009
[考研] 280求调剂 +21 咕噜晓晓 2026-04-02 22/1100 2026-04-04 11:12 by 猪会飞
[考研] 本9一志愿2 0854低分专硕286求调剂 +9 芒种111 2026-04-04 9/450 2026-04-04 11:01 by tangruihua
[基金申请] 同年申报,是不是就不会派给你函评本子了? +4 redcom 2026-03-29 4/200 2026-04-04 10:08 by kudofaye
[考研] 材料科学与工程考研 +10 拯救皮特托先生 2026-04-02 10/500 2026-04-03 23:57 by userper
[考研] 350一志愿北京航空航天大学08500材料科学与工程求调剂 +5 kjnasfss 2026-04-03 5/250 2026-04-03 22:29 by 无际的草原
[考研] 286求调剂 +8 lim0922 2026-04-02 8/400 2026-04-03 20:19 by rzh123456
[考研] 303求调剂 +9 DLkz1314. 2026-03-30 9/450 2026-04-03 18:34 by ls刘帅
[考研] 考研调剂 +3 Draa 2026-04-03 3/150 2026-04-03 17:37 by hgwz7468
[考研] 286求调剂 +7 Faune 2026-03-30 7/350 2026-04-03 10:14 by linyelide
[考研] 环境工程297分求调剂一志愿杭高院 +15 GENJIOW 2026-03-31 16/800 2026-04-02 17:56 by cyh—315
[考研] 材料调剂 +12 一样YWY 2026-04-01 12/600 2026-04-02 00:21 by 百秒光年
[考研] 290求调剂 +5 dfffsar 2026-03-29 5/250 2026-04-01 19:45 by 6781022
[考研] 生物学296求调剂 +10 汤圆包 2026-03-29 14/700 2026-04-01 10:44 by 求调剂zz
[考研] 335求调剂 +3 321* 2026-03-31 4/200 2026-04-01 00:00 by 321*
[考研] 085601英二数二求调剂 总分325 +4 余航航 2026-03-31 4/200 2026-03-31 17:38 by 唐沐儿
信息提示
请填处理意见