24小时热门版块排行榜    

查看: 655  |  回复: 3
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

zxqworld

新虫 (初入文坛)

[求助] 求大神帮忙看一下 我写的积分法 求取动力学参数的 程式 已有2人参与

function KineticsEst1_int
% 动力学参数辨识: 用积分法进行反应速率分析得到速率常数k和反应级数n
clear all
clc

global X
t =[30:30:120];
X1=[67.37 58.28 45.32 32.1];
X2=[7.88 17.88 17.45 26.43];
X3=[2.48 9.09 11.84 13.65];
X4=[1.58 0 0.94 0];
X5=[20.69 14.75 24.45 27.82];
% 非线性拟合
k0 = [0.00594 0.00391 0.00222 0.00810 0.00020 0.01071 ];
n0 =[1 1 1 1.43 1.38 1.26];
beta0=[k0; n0];
tspan = [30:120];
X0 = [67.37 7.88 2.48 1.58 20.69];
[beta,resnorm,residual,exitflag,output,lambda,jacobian] = ...
    lsqnonlin(@OptObjFunc,beta0,[],[],[],tspan,X0,X);
ci = nlparci(beta,resid,jacobian);

% 拟合效果图(实验与拟合的比较)
figure(1)
[t4plot X4plot] = ode45(@KineticsEqs,[tspan],X0,[],beta);
plot(t,X(:,1),'bo',t4plot,X4plot,'k-')
legend('Exp','Model')
xlabel('时间 min')
ylabel('收率C_C, %')

% 残差关于拟合值的残差图
[t Xc] = ode45(@KineticsEqs,tspan,X0,[],k,n);
figure
plot(Xc,resid,'*')
xlabel('收率拟合值(%)')
ylabel('残差R (%)')
refline(0,0)

% 参数辨识结果
fprintf('Estimated Parameters:\n')
fprintf('\tk = %.4f ± %.4f\n',k,ci(1,2)-k)
fprintf('\tn = %.2f ± %.2f\n',n,ci(2,2)-n)

% ------------------------------------------------------------------
function f = OptObjFunc(k,n,tspan,X0,X)
tspan=[30:30:120]
[t Xc] = ode45(@KineticsEqs,tspan,X0,[],k,n);
f1 = Xc(:,1) - X(:,1);
f2 = Xc(:,2) - X(:,2);
f3 = Xc(:,3) - X(:,3);
f4 = Xc(:,4) - X(:,4);
f5 = Xc(:,5) - X(:,5);
f = f1+ f2+ f3+ f4+ f5;



% ------------------------------------------------------------------
function dXdt = KineticsEqs(t,X,k,n)
dXdt =  ...
[ ( -(k(1)+k(2)+k(3)+k(4))*X(1)^n(1)  )
   ( k(2)*X(1)^n(2))
   ( k(1)*X(1)^n(1)+k(5)*X(4)^n(5)+k(6)*X(5)^n(6) )
   ( k(3)^X(1)^n(3)-k(5)*X(4)^n(5))
   ( k(4)*X(1)^n(4)-k(6)*X(5)^n(6))
];

程序错误好多,但是不知道怎么改,尤其是 非线性拟合部分,关于矩阵beta,我是参照一本书上的一个例题写的,但是他只有一个方程,我有5个,还请各位大神帮忙看一下。。万分感谢!!
回复此楼

» 猜你喜欢

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

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zxqworld

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by dingd at 2014-05-23 10:21:25
微分方程拟合你试试1stOpt,更简单好用些。

好的 ,我试试看 。因为比较急 ,没用过 ,不知道会不会比较麻烦。感谢!
3楼2014-05-23 10:43:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 4 个回答

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
微分方程拟合你试试1stOpt,更简单好用些。
2楼2014-05-23 10:21:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

云少爷

新虫 (初入文坛)

【答案】应助回帖

楼主可以看一下实用化工计算机模拟-Matlab在化学工程中的应用,第七章讲到了你问的问题,我记得有一个跟你问题类似的程序
4楼2016-11-09 11:58:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 298求调剂 +4 上岸6666@ 2026-03-20 4/200 2026-03-21 17:14 by 学员8dgXkO
[考研] 【考研调剂】化学专业 281分,一志愿四川大学,诚心求调剂 +10 吃吃吃才有意义 2026-03-19 10/500 2026-03-21 16:43 by macy2011
[考研] 317求调剂 +8 申子申申 2026-03-19 14/700 2026-03-21 16:29 by 我的船我的海
[考研] 求调剂 +3 Ma_xt 2026-03-17 3/150 2026-03-21 02:05 by JourneyLucky
[考研] 一志愿西南交大,求调剂 +5 材化逐梦人 2026-03-18 5/250 2026-03-21 00:26 by JourneyLucky
[考研] 288求调剂 +16 于海海海海 2026-03-19 16/800 2026-03-20 22:28 by JourneyLucky
[考研] 一志愿中南化学(0703)总分337求调剂 +8 niko- 2026-03-19 9/450 2026-03-20 21:57 by luoyongfeng
[考研] 0817 化学工程 299分求调剂 有科研经历 有二区文章 +22 rare12345 2026-03-18 22/1100 2026-03-20 20:39 by zhukairuo
[考研] 319求调剂 +3 小力气珂珂 2026-03-20 3/150 2026-03-20 19:47 by JourneyLucky
[考研] 0703化学调剂 ,六级已过,有科研经历 +13 曦熙兮 2026-03-15 13/650 2026-03-20 19:35 by Dream007008
[考研] 工科材料085601 279求调剂 +7 困于星晨 2026-03-17 9/450 2026-03-20 17:38 by 无懈可击111
[考研] 材料与化工求调剂 +7 为学666 2026-03-16 7/350 2026-03-19 14:48 by 尽舜尧1
[考研] 0854可跨调剂,一作一项核心论文五项专利,省、国级证书40+数一英一287 +8 小李0854 2026-03-16 8/400 2026-03-18 14:35 by 搏击518
[考研] 326求调剂 +5 上岸的小葡 2026-03-15 6/300 2026-03-17 17:26 by ruiyingmiao
[考研] 考研化学学硕调剂,一志愿985 +4 张vvvv 2026-03-15 6/300 2026-03-17 17:15 by ruiyingmiao
[考研] 308求调剂 +4 是Lupa啊 2026-03-16 4/200 2026-03-17 17:12 by ruiyingmiao
[考研] 材料专硕326求调剂 +6 墨煜姒莘 2026-03-15 7/350 2026-03-17 17:10 by ruiyingmiao
[考研] 一志愿南京大学,080500材料科学与工程,调剂 +4 Jy? 2026-03-16 4/200 2026-03-17 11:02 by gaoqiong
[考研] [导师推荐]西南科技大学国防/材料导师推荐 +3 尖角小荷 2026-03-16 6/300 2026-03-16 23:21 by 尖角小荷
[考研] 070300化学学硕求调剂 +6 太想进步了0608 2026-03-16 6/300 2026-03-16 16:13 by kykm678
信息提示
请填处理意见