24小时热门版块排行榜    

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

修竹好衰

新虫 (初入文坛)

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

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

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

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

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

hzlhm

至尊木虫 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
你的问题,可能出现在初值设定上不合理。
QQ:2120156492
4楼2022-03-06 20:23:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
不应助 确定回帖应助 (注意:应助才可能被奖励,但不允许灌水,必须填写15个字符以上)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085701环境工程专业,初试305,均过国家A区线 +7 卡卡来了@ 2026-03-07 8/400 2026-03-08 06:40 by 刘兵
[考研] 348求调剂 +3 wyx79618 2026-03-06 5/250 2026-03-08 03:47 by lfhuang
[考研] 347求调剂 +3 浮云满足 2026-03-07 3/150 2026-03-08 03:43 by lfhuang
[考研] 08工科 +4 li李乐成 2026-03-06 4/200 2026-03-07 21:46 by 韩应许
[考研] 一志愿211 化学305分求调剂 +3 0703杨悦305分 2026-03-05 3/150 2026-03-07 21:15 by yinhuanshun
[考研] 0307化学求调剂 +6 0ok0k 2026-03-07 6/300 2026-03-07 20:10 by pies112
[考研] 第一志愿上海大学,专业化学工程与技术,总分288,求调剂 +3 1829197082 2026-03-07 3/150 2026-03-07 19:14 by houyaoxu
[考研] 材料学硕318求调剂 +21 February_Feb 2026-03-01 24/1200 2026-03-06 16:08 by @飒飒飒飒
[考研] 化学专业调剂 +5 好好好1233 2026-03-04 6/300 2026-03-06 15:38 by @飒飒飒飒
[考研] 287求调剂 +3 看看我. 2026-03-05 6/300 2026-03-06 10:40 by Iveryant
[考研] 282求调剂 +7 夕~日 2026-03-05 8/400 2026-03-05 21:31 by zzpnuli111
[考研] 材料学学硕308分/本科东北大学/一志愿西北工业大学/ 5+3 苏尧幺幺 2026-03-03 8/400 2026-03-05 16:06 by njzyff
[考研] 材料085600 303求调剂 +7 1bygone 2026-03-04 7/350 2026-03-05 09:39 by oxidpl
[考研] 264求调剂 +8 26调剂 2026-03-03 8/400 2026-03-04 20:50 by 一切OK
[考研] 武理材料工程302调剂 +3 Doleres 2026-03-03 6/300 2026-03-04 15:54 by zhukairuo
[考研] 264求调剂 +3 thext 2026-03-03 3/150 2026-03-04 09:29 by 热情沙漠
[考研] 环境调剂 +8 chenhanheng 2026-03-02 8/400 2026-03-03 22:13 by 刘兵
[考研] 清华大学 材料与化工 353分求调剂 +5 awaystay 2026-03-02 6/300 2026-03-03 09:03 by houyaoxu
[考研] 338求调剂 +5 18162027187 2026-03-02 6/300 2026-03-03 07:52 by njzyff
[基金申请] 此成果不能导入原因:元数据必填信息不完整,可 进行补充。 +4 Kittylucky 2026-03-02 5/250 2026-03-02 11:07 by jurkat.1640
信息提示
请填处理意见