声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 922|回复: 3

[编程技巧] 请教曲线拟合问题!

[复制链接]
发表于 2009-3-19 19:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
function aaa
xdata=[-2.018;-1.818;-1.236;-1.018;-0.855;-0.018;0.291;0.691];
ydata=[1.025;1.161;1.193;1.064;1.139;1.232;1.309;1.428];
x=lsqcurvefit(@myfun,[1 1],xdata,ydata)

function F=myfun(x,xdata)
F=x(1)/(1+(x(1)/1.139-1)*exp(-x(2)*(xdata+0.855)));

我想要拟合公式y=a/(1+(a/1.139-1)*exp(-b*(x+0.855))),并且求出a和b的值。上面是我编的程序,运行时出现如下错误:

??? Error using ==> optim\private\lsqncommon
Function value and YDATA sizes are incommensurate.
Error in ==> lsqcurvefit at 182
[x,Resnorm,FVAL,EXITFLAG,OUTPUT,LAMBDA,JACOB] = ...
Error in ==> aaa at 4
x=lsqcurvefit(@myfun,[1 1],xdata,ydata)
请大家帮忙解决!谢谢了!
回复
分享到:

使用道具 举报

发表于 2009-3-20 09:18 | 显示全部楼层
曲线拟合,可以直接调用工具箱
发表于 2009-3-20 09:51 | 显示全部楼层
function F=myfun(x,xdata)
F=x(1)./(1+(x(1)/1.139-1)*exp(-x(2)*(xdata+0.855)));  %%注意,分母部分是矩阵形式,要使用./

评分

1

查看全部评分

 楼主| 发表于 2009-3-21 16:20 | 显示全部楼层

回复 板凳 ydlcsu 的帖子

谢谢,已调好
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-5-20 13:13 , Processed in 0.056367 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表