24小时热门版块排行榜    

查看: 869  |  回复: 9
【悬赏金币】回答本帖问题,作者hzd250将赠送您 10 个金币
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

hzd250

新虫 (小有名气)

[求助] matlab拟合反应动力学已有2人参与

刚入门matlab的小白,最近想做反应的动力学,按照B站up主的视频自己写了一段代码,但是运行总是出问题:

错误使用 odearguments (第 93 行);FUNC 必须返回列向量,出错 ode45 (第 115 行),odearguments(FcnHandlesUsed, solver_name, ode, tspan, y0, options, varargin);
出错 Kinetics>fun (第 67 行),[t,x]=ode45(@func,tspan,x0,[],k);
出错 lsqnonlin (第 218 行),initVals.F = feval(funfcn{3},xCurrent,varargin{:});出错 Kinetics (第 18 行),lsqnonlin(@fun,k0,lb,ub,[],yexp);%非线性最小二乘法。原因:Failure in initial objective function evaluation. LSQNONLIN cannot continue.

下面是我写的代码,读取的Excel表格里有5列*7行的实验数据,劳烦大佬帮我瞅瞅哪里需要改动,万分感谢。

function Kinetics
%反应一:A+B=C+M
%r=k*XA*XB-K*XC*XM
%反应二:A+C=D+M
%r=K*XA*XC-K*XD*XM
%反应三:B+C=E+M
%r=K*XB*XC-K*XE*XM
%XM=0.175
clc
clear all;
global a b
tspan=[0.5 1 4 6 8 12 16];
yexp=xlsread('reaction.xls');
k0=[0.1 0.01 0.01 0.001 0.001 0.001];%参数初值
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);%非线性最小二乘法
tspan=[0.5 1 4 6 8 12 16];
a=1;
b=a+6;
x0=yexp(a,;%积分初值
[t,x]=ode45(@func,tspan,x0,[],k);
t1=linspace(0.5,16,200);
ya1=spline(t,x(:,1),t1);%动力学计算得到的点进行样条插值
ya2=spline(t,x(:,2),t1);
ya3=spline(t,x(:,3),t1);
ya4=spline(t,x(:,4),t1);
ya5=spline(t,x(:,5),t1);
for m=1:7
    for n=1:5
        yy(a+m-1,n)=x(m,n);%每一次的值存入yy矩阵
    end
end
figure(1)
plot(tspan,yexp(a:b,1),'k^',t1,ya1,'k-',tspan,yexp(a:b,2),'ro',t1,ya2,'r-',tspan,yexp(a:b,3),'bd',t1,ya3,'b-',...
tspan,yexp(a:b,4),'g*',t1,ya4,'g-',tspan,yexp(a:b,5),'yp',t1,ya5,'y-');
legend('','A浓度','','B浓度','','C浓度','','D浓度','','E浓度');
xlabel('t(h)');ylabel('浓度(mol/L)');title('170℃ 0.1wt%催化剂');
t1=linspace(0.5,16,200);
z1=spline(t,yy(1:7,1),t1);
h1=spline(t,yy(1:7,2),t1);
s1=spline(t,yy(1:7,3),t1);
b1=spline(t,yy(1:7,4),t1);
u1=spline(t,yy(1:7,5),t1);
xlswrite('result.xls',[t1' z1' h1' s1' b1' u1'],'sheet1');
xlswrite('result.xls',residual,'sheet2');
Ne = length(yexp(:,2));     %模型适定性判别
Np = length(k);
[rho2,F] = rho2_F(k,yexp,resnorm,Ne,Np);
ci=nlparci(k,residual,jacobian)
fprintf('\t k1,0=%.1f ± %.4f\n',k(1),ci(1,2)-k(1));
fprintf('\t k2,0=%.1f ± %.4f\n',k(2),ci(2,2)-k(2));
fprintf('\t k3,0=%.1f ± %.4f\n',k(3),ci(3,2)-k(3));
fprintf('\t k4,0=%.1f ± %.4f\n',k(4),ci(4,2)-k(4));
fprintf('\t k5,0=%.1f ± %.4f\n',k(5),ci(5,2)-k(5));
fprintf('\t 残差平方和:%.3f\n',resnorm)
fprintf('\t 实验点数和自由度分别为 Ne = %d和 Np = %d\n',Ne,Np)
fprintf('\t 决定性指标ρ^2: %.4f\n',rho2)
fprintf('\t F比: %.3f\n\n',F)
%=================================================================================
function f=fun(k,yexp)
f=[];
tspan=[0.5 1 4 6 8 12 16];
a=1;
x0=yexp(a,;
[t,x]=ode45(@func,tspan,x0,[],k)
d=a+6;
yc1=x(:,1);
yc2=x(:,2);
yc3=x(:,3);
yc4=x(:,4);
yc5=x(:,5);
f11=yexp(a:d,1)-yc1;
f12=yexp(a:d,2)-yc2;
f13=yexp(a:d,3)-yc3;
f14=yexp(a:d,4)-yc4;
f15=yexp(a:d,5)-yc5;
ff=[f11 f12 f13 f14 f15];
f=[f;ff];
%=================================================================================
function dxdt=func(t,x,k)
r1=-k(1)*x(1)*x(2)-k(2)*x(1)*x(3)+k(4)*x(3)*0.175+k(5)*x(4)*0.175;
r2=-k(1)*x(1)*x(2)-k(3)*x(2)*x(3)+k(4)*x(3)*0.175+k(6)*x(5)*0.175;
r3=k(1)*x(1)*x(2)+k(5)*x(4)*0.175+k(6)*x(5)*0.175-k(2)*x(1)*x(3)-k(3)*x(2)*x(3)-k(4)*x(3)*0.175;
r4=k(2)*x(1)*x(3)-k(5)*x(4)*0.175;
r5=k(3)*x(2)*x(3)-k(6)*x(5)*0.175;
dxdt=[r1 r2 r3 r4 r5]
%=================================================================================
function [rho2,F] = rho2_F(k,yexp,s,Ne,Np)
y=yexp.^2;
sy = sum(y();
rho2 = 1 - s/sy;              %rho2: 决定性指标
F = (sy - s)*(Ne-Np)/(Np*s);  %F:F比
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzd250

新虫 (小有名气)

送红花一朵
引用回帖:
5楼: Originally posted by hzlhm at 2021-05-18 18:39:58
每列数据对应的变量是什么?...

每列数据对应的变量就是五中物质的浓度变化:x1 x2 x3 x4 x5,就是后面的微分速率方程里面的x1 x2 x3 x4 x5

发自小木虫Android客户端
7楼2021-05-18 21:34:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 10 个回答

hzlhm

至尊木虫 (著名写手)

【答案】应助回帖

有具体的数据吗?可以发给我吗?,可以试一试帮你找问题?

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

QQ:2120156492
2楼2021-05-17 22:00:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzd250

新虫 (小有名气)

送红花一朵
引用回帖:
2楼: Originally posted by hzlhm at 2021-05-17 22:00:00
有具体的数据吗?可以发给我吗?,可以试一试帮你找问题?

有的,太谢谢你了
matlab拟合反应动力学



发自小木虫Android客户端
3楼2021-05-18 10:22:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzd250

新虫 (小有名气)

引用回帖:
3楼: Originally posted by hzd250 at 2021-05-18 10:22:08
有的,太谢谢你了

...

这个是简化的数据
matlab拟合反应动力学-1



发自小木虫Android客户端
4楼2021-05-18 10:52:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
不应助 确定回帖应助 (注意:应助才可能被奖励,但不允许灌水,必须填写15个字符以上)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 工材01送了吗? +8 xiaopang8958 2024-05-25 15/750 2024-05-29 20:03 by xiaopang8958
[考博] 催化、储能博士招聘 +4 dfjsf 2024-05-23 5/250 2024-05-29 19:25 by 苦练投篮
[教师之家] 女博士高校择业三天之内签合同,求支招 +41 chengmy19 2024-05-23 59/2950 2024-05-29 19:08 by mingxu
[论文投稿] 纠结选哪一个期刊,电化学领域 50+5 Freya163 2024-05-28 5/250 2024-05-29 16:33 by ca0yan9
[论文投稿] 共同通讯谁投稿? +3 qvhm2609 2024-05-23 11/550 2024-05-29 14:52 by a50044758
[考博] 申博求助?本硕双非一篇三区和四区去985工科非天坑专业有没有希望? +3 LYS1200 2024-05-29 5/250 2024-05-29 14:45 by 未来富婆蛙
[电化学] 有锂金属软包电池代工公司代做软包嘛 +3 yyywj995 2024-05-26 3/150 2024-05-29 14:33 by 单细胞鱼儿
[基金申请] 九部门发文:不得将专利授权数量作为人才评价、项目评审、职称评定、高校评价等的条件 +13 sjtu2012 2024-05-28 16/800 2024-05-29 13:52 by 知识产权服务
[论文投稿] 真急着毕业,CPB主编终审17天了,邮件催稿了两次,就是一点动静没有 5+3 kkkk夏 2024-05-28 6/300 2024-05-29 11:18 by hitsdu
[论文投稿] 高手朋友推荐比较容易投稿和录用的SCI期刊,不投稿收费SC,对分区没有要求 5+3 xintangren 2024-05-28 4/200 2024-05-29 10:46 by xintangren
[有机交流] 液相纯度高,但产品析不太出来 10+4 cui19236 2024-05-27 8/400 2024-05-29 09:09 by chu-yue
[论文投稿] EI学报,一审返修后,为啥不再送审,直接终审中? +4 qweasd12345 2024-05-27 6/300 2024-05-29 00:02 by dut_ameng
[基金申请] E05青基有几个评审 +4 KYXY123 2024-05-28 4/200 2024-05-28 19:25 by popt2t
[基金申请] 河北省基金 50+3 晓晓爱翠翠 2024-05-23 24/1200 2024-05-28 14:49 by 晓晓爱翠翠
[有机交流] 机理求助 200+4 15147165026 2024-05-26 10/500 2024-05-28 14:42 by 江东闲人
[材料综合] 求助,刚入门MOF合成,实验总是失败 20+3 张月半 2024-05-25 8/400 2024-05-28 09:20 by 我想更懂你29
[基金申请] 科研之友阅读量近一周增加了200多。 +13 hdzw9071 2024-05-24 14/700 2024-05-27 17:29 by leeeru
[基金申请] 函评什么时候结束 +9 阿呆不呆 2024-05-23 10/500 2024-05-27 15:51 by zsy4657608
[基金申请] 感觉自然基金限制通过比例就是有点扯,学学B口,化学学部,不限制比例。 +10 wsjing 2024-05-26 14/700 2024-05-27 11:57 by kanmiaolucky
[论文投稿] 真是奇怪的编辑部? +5 jjdg 2024-05-23 5/250 2024-05-25 21:57 by cqu_zzh
信息提示
请填处理意见