| 查看: 466 | 回复: 1 | |||
[交流]
【求助】matlab 拟合问题
|
|
自变量t是时间,一维数组; 因变量c是浓度,包含2种,一个是料液相浓度,另一个是接受相浓度,二维数组。 c1=g(K1,K2,t), c2=G(K1,K2,t); g和G是不同的函数。 现在有实验数据t和c=[c1 c2]; 请问如何在matlab中编程对参数K1,K2进行非线性拟合? 注意,K1,K2在c1,c2中都出现了,所以2个函数需要同时拟合。我在用nlinfit函数时发现好像只能对一个因变量进行拟合。 敬请赐教!谢谢 |
» 猜你喜欢
带资进组求博导收留
已经有9人回复
求助大佬们,伤口沾上了乙腈
已经有6人回复
26申博自荐
已经有6人回复
最近几年招的学生写论文不引自己组发的文章
已经有9人回复
A期刊撤稿
已经有4人回复
» 本主题相关价值贴推荐,对您同样有帮助:
请教matlab反应动力学参数估计遇到的问题,谢谢
已经有15人回复
matlab拟合方程参数时初值的选择
已经有15人回复
matlab拟合求值
已经有17人回复
在matlab中拟合曲面的表达式
已经有29人回复
matlab 求指点 动力学方程拟合过程中导数的获取
已经有10人回复
matlab拟合拟均相动力学参数
已经有6人回复
需要用matlab拟合数据的外行人急需帮助
已经有10人回复
matlab非线性参数拟合问题
已经有7人回复
【求助】matlab曲面拟合表达式
已经有10人回复
【求助】使用Matlab拟合反应动力学方程问题
已经有7人回复
» 抢金币啦!回帖就可以得到:
南京都市圈高校大龄离异博士征友
+2/570
【CSC招生】拉瓦尔大学流体力学博士项目
+3/195
湖南师范大学医工交叉科研团队招收博士研究生
+1/191
《春节催婚季,90后男生在线“招募”战友,一起过个轻松年》
+1/153
新加坡国立大学张阳教授课题组招聘博士后(AI与生物医学方向)
+1/124
坐标北京不异地
+1/80
中国科学院化学研究所招收2026级博士生
+5/60
【CSC招生】荷兰莱顿大学医学中心LKEB图像处理实验室 招收2026年CSC博士生多名
+1/38
中科院深圳先进院成会明院士\唐永炳国家杰青团队招聘
+2/38
中国科学院大连化学物理研究所DNL0902研究组招聘博士后和职工
+1/18
山东大学集成电路学院招收2026年9月入学的博士研究生
+1/13
中南大学化学化工学院高性能聚合物团队2026年诚聘博士后或青年教师
+1/8
天津大学化学系吴立朋课题组申请考核制博士招生/博后招聘
+1/8
中科院苏州医工所单细胞分析技术中心招聘公告(细胞分选、图像识别、流式应用方向)
+1/7
北京理工大学集成电路与电子学院国家杰青团队招博士后及科研助理
+1/5
中科院和北京工商大学招收2026博士/化学或生物背景
+1/4
中国地质大学(武汉)新能源学院地下工程防灾减灾与储能团队招聘科研助理
+1/4
西交利物浦大学/GaN电力电子器件方向/张洁老师招博士研究生
+1/3
英国兰卡斯特大学(Lancaster University)大模型、计算机视觉PhD招生
+1/2
中国科大电池方向任晓迪课题组招收2026级博士生-电解液/电池安全性/人工智能方向
+1/1
flyinuniverse58(金币+10):虽然和我的目标有些距离,但还是感谢你为我提供了思路(我在题目中说了y是2个不同的函数,不是x) 2010-11-19 14:50:25
flyinuniverse58(金币+10):没人回复了,都给你吧,谢谢 2010-12-23 08:10:11
flyinuniverse58(金币+10):没人回复了,都给你吧,谢谢 2010-12-23 08:10:11
|
请楼主 依葫芦画瓢,保证算的出来!! 1 设定目标函数. (M函数书写)% 可以是任意的 例如: function f=mydata(a,data) %y的值目标函数值 或者是第三维的,a=[a(1) ,a(2)] 列向量 x=data(1, ; %data 是一2维数组,x=x1y=data(2, ; %data 是一2维数组,x=x2 f=a(1)*x+a(2)*x.*y; %这里的a(1), a(2)为目标函数的系数值。 f的值相当于ydata的值 2 然后给出数据xdata和ydata的数据和拟合函数lsqcurvefit 例如: x1=[1.0500 1.0520 1.0530 1.0900 1.0990 1.1020 1.1240 1.1420... 1.1490 1.0500 1.0520 1.0530 1.0900 1.0990 1.1020 1.1240 1.1420 1.1490]; x2=[3.8500 1.6500 2.7500 5.5000 7.7000 3.3000 4.9500 8.2500 11.5500... 1.6500 2.7500 3.8500 7.7000 3.3000 5.5000 8.2500 11.5500 4.9500]; ydata=[56.2000 62.8000 62.2000 40.8000 61.4000 57.5000 44.5000 54.8000... 53.9000 64.2000 62.9000 64.1000 63.0000 62.2000 64.2000 63.6000... 52.5000 62.0000]; data=[x1;x2]; %类似于将x1 x2整合成一个2维数组。 a0= [-0.0014,0.07]; option=optimset('MaxFunEvals',5000); format long; [a,resnorm]=lsqcurvefit(@mydata,a0,data,ydata,[],[],option); yy=mydata(a,data); result=[ydata' yy' (yy-ydata)'] % a的值为拟合的目标函数的参数值 利用lsqcurvefit进行拟合的 它完整的语法形式是: % [x,resnorm,residual,exitflag,output,lambda,jacobian] =lsqcurvefit(fun,x0,xdata,ydata,lb,ub,options) |
2楼2010-11-19 10:19:10













回复此楼
; %data 是一2维数组,x=x1