24小时热门版块排行榜    

查看: 1603  |  回复: 5

姜玉旺

木虫 (著名写手)

[求助] 关于matlab微分、及非线性拟合问题

最近一直苦苦思索化学反应速率的问题,想用matlab来求微分拟合非线性曲线求出常数,可我确实不懂matlab,望各位大侠不吝赐教,帮我编写出程序,最好能有图形结合,小弟感激涕零:
我的方程式是(dx)/(dt)=a*c*[(K-1)*x^2-32*K*x+31*K]
t,x的取值为t=0,x=0;t=1,x=0.0355;t=2,x=0.1014;t=3,x=0.1394;t=4,x=0.2147;t=5,x=0.2823;t=6,x=0.3274;t=7,x=0.3717;t=8,x=0.4095.
其中a,K未知,c=1.213.
小弟已经计算好几天了,其在无能为力,拜托了,帮我编出程序。。。感谢了。。。
回复此楼

» 猜你喜欢

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

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

东平Modelon

金虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
xiegangmai: 金币+2, 谢谢参与 2013-01-14 00:21:28
姜玉旺: 金币+5, ★★★很有帮助 2013-01-14 08:52:30
分离微分方程变量以后,如果懒得用配方法解出微分方程的话,弄个mathematica可以直接用解析法解
Integrate[1/( a*c*((k - 1)*x^2 + 32*k*x + 31*k)), x]

                       16 k - x + k x
          ArcTanh[------------------------]
                  Sqrt[k] Sqrt[31 + 225 k]
             -(---------------------------------)           - 66  = t
            a c Sqrt[k] Sqrt[31 + 225 k]


然后显然
f(x_n) - t_n =0
喜欢用fmincon做优化 还是用nlinfit做非线性回归求系数也是随便你啦。
2楼2013-01-13 21:06:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

姜玉旺

木虫 (著名写手)

引用回帖:
2楼: Originally posted by 东平Modelon at 2013-01-13 21:06:18
分离微分方程变量以后,如果懒得用配方法解出微分方程的话,弄个mathematica可以直接用解析法解
Integrate

                       16 k - x + k x
          ArcTanh
                  Sqrt Sqrt
         ...

我输进去后,怎么出现以下问题了?在帮解决一下吧
??? Integrate[1/( a*c*((k - 1)*x^2 + 32*k*x + 31*k)), x]
             |
Error: Unbalanced or unexpected parenthesis or bracket.
3楼2013-01-14 14:08:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

东平Modelon

金虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★
姜玉旺: 金币+5, ★★★很有帮助 2013-01-15 10:48:45
引用回帖:
3楼: Originally posted by 姜玉旺 at 2013-01-14 07:08:23
我输进去后,怎么出现以下问题了?在帮解决一下吧
??? Integrate
             |
Error: Unbalanced or unexpected parenthesis or bracket....

积分我是用MATHEMATICA做的,不是matlab。


                       16 k - x + k x
          ArcTanh[------------------------]
                  Sqrt[k] Sqrt[31 + 225 k]
     -          (---------------------------------)           - 66  - t = 0
            a c Sqrt[k] Sqrt[31 + 225 k]
变换成matlab的代碼:


然后在matlab可以定义newfunction.m

function result = newfunction(X, beta)
k = beta(1);
a = beta(2);
x = X(1);
t = X(2);

result = 前面那个公式


最后用nlinfit(X, Y, beta0)算结果
其中
X = [ 0, 0; 1, 0.0355; 等等]
Y = [0 ; 0 等等](和X等高)
beta0 = [ 0, 0] 是初值,你猜一个吧。看code就可以知道前面是k后面是a了。
4楼2013-01-15 02:54:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

姜玉旺

木虫 (著名写手)

引用回帖:
4楼: Originally posted by 东平Modelon at 2013-01-15 02:54:24
积分我是用MATHEMATICA做的,不是matlab。


                       16 k - x + k x
          ArcTanh
                  Sqrt Sqrt
     -          (---------------------------------)           -  ...

谢谢哈,我试试吧
5楼2013-01-15 10:49:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
姜玉旺: 金币+10, ★★★很有帮助 2013-11-27 18:37:37
用1stOpt直接微分方程拟合:
CODE:
Constant c=1.213;
Variable t,x;
ODEFunction x'=a*c*((K-1)*x^2-32*K*x+31*K);
Data;
0,0
1,0.0355
2,0.1014
3,0.1394
4,0.2147
5,0.2823
6,0.3274
7,0.3717
8,0.4095

均方差(RMSE):0.0144298065185047
残差平方和(SSE):0.00166575452929184
相关系数(R): 0.995283478470763
相关系数之平方(R^2): 0.990589202516862
确定系数(DC): 0.986895420543766
F统计(F-Statistic): 457.855211610462

参数                  最佳估算
--------------------        -------------
a        -0.101555842272903
k        -0.0151477051447373

====== 结果输出 ======

文件: 数据文件-1
No        t        目标 x        计算 x
1        1        0.0355        0.0562847266411599
2        2        0.1014        0.110052998758528
3        3        0.1394        0.162114481657899
4        4        0.2147        0.213185538231459
5        5        0.2823        0.263930448271775
6        6        0.3274        0.314996671293445
7        7        0.3717        0.367048236670994
8        8        0.4095        0.420800978410109
6楼2013-11-22 12:46:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 姜玉旺 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 277材料科学与工程080500求调剂 +7 自由煎饼果子 2026-03-16 7/350 2026-03-22 22:40 by ACS Nano——
[考研] 311求调剂 +6 冬十三 2026-03-18 6/300 2026-03-22 20:18 by edmund7
[考研] 一志愿 西北大学 ,070300化学学硕,总分287,双非一本,求调剂。 +3 晨昏线与星海 2026-03-20 3/150 2026-03-22 16:00 by ColorlessPI
[考研] 269专硕求调剂 +6 金恩贝 2026-03-21 6/300 2026-03-22 14:31 by ColorlessPI
[考研] 材料学硕301分求调剂 +7 Liyouyumairs 2026-03-21 7/350 2026-03-21 22:31 by peike
[考研] 302求调剂 +12 呼呼呼。。。。 2026-03-17 12/600 2026-03-21 17:29 by ColorlessPI
[考研] 299求调剂 +5 shxchem 2026-03-20 7/350 2026-03-21 17:09 by ColorlessPI
[基金申请] 学校已经提交到NSFC,还能修改吗? 40+4 babangida 2026-03-19 9/450 2026-03-21 16:12 by babangida
[考研] 材料与化工(0856)304求 B区 调剂 +3 邱gl 2026-03-21 3/150 2026-03-21 13:47 by lature00
[考研] 材料学学硕080502 337求调剂-一志愿华中科技大学 +4 顺顺顺mr 2026-03-18 5/250 2026-03-21 10:22 by luoyongfeng
[考研] 南昌大学材料专硕311分求调剂 +6 77chaselx 2026-03-20 6/300 2026-03-21 07:24 by JourneyLucky
[考研] 机械专硕299求调剂至材料 +3 kkcoco25 2026-03-16 4/200 2026-03-21 03:52 by JourneyLucky
[考研] 301求调剂 +10 yy要上岸呀 2026-03-17 10/500 2026-03-21 03:14 by JourneyLucky
[考研] 265求调剂 +9 梁梁校校 2026-03-17 9/450 2026-03-21 02:17 by JourneyLucky
[考研] 一志愿华中科技大学,080502,354分求调剂 +5 守候夕阳CF 2026-03-18 5/250 2026-03-21 01:06 by JourneyLucky
[考研] 261求B区调剂,科研经历丰富 +3 牛奶很忙 2026-03-20 4/200 2026-03-20 19:34 by JourneyLucky
[考研] 0856调剂,是学校就去 +8 sllhht 2026-03-19 9/450 2026-03-20 14:25 by 无懈可击111
[考研] 081700化工学硕调剂 +3 【1】 2026-03-16 3/150 2026-03-19 23:40 by edmund7
[考研] 283求调剂 +3 听风就是雨; 2026-03-16 3/150 2026-03-17 07:41 by 热情沙漠
[考研] 070300化学学硕求调剂 +6 太想进步了0608 2026-03-16 6/300 2026-03-16 16:13 by kykm678
信息提示
请填处理意见