[求助]:利用最小二乘法来优化参数的问题?
各位高手,有谁知道有关非线性最小二乘法在MATLAB中实现的程序,能否告知一二,谢谢![ 本帖最后由 咕噜噜 于 2007-6-15 08:54 编辑 ] 有现成的函数,lsqnonlin 现在有一段这样的程序,如下:
首先编制非线性模型m文件(sta67_2m.m):
function yy=model(beta0,x)
a1=beta0(1);
b1=beta0(2);
a2=beta0(3);
b2=beta0(4);
a3=beta0(5);
b3=beta0(6);
a4=beta0(7);
b4=beta0(8);
a5=beta0(9);
b5=beta0(10);
dd1=a1*sin(4.3945*dd2+b1)+a2*sin(4.3945*dd2+b2)+a3*sin(4.3945*dd2+b3)+a4*sin(4.3945*dd2+b4)+a5*sin(4.3945*dd2+b5);
然后在命令栏里面输入:
yy=Data(2100*500:2103*500);dd1=yy;
x=0:0.002:3;dd2=x';
beta0=;
betafit=nlinfit(dd2,dd1,'sta67_2m.m',beta0);
这里用的是nlinfit命令,我试着运行了一下,结果是这样:
??? Error using ==> nlinfit
The inline model function generated the following error:
Error using ==> inline.subsref
Too many inputs to inline function.
哪位高手能帮我解决这个问题呀?谢谢! function yy=model(beta0,x)
a1=beta0(1);
b1=beta0(2);
a2=beta0(3);
b2=beta0(4);
a3=beta0(5);
b3=beta0(6);
a4=beta0(7);
b4=beta0(8);
a5=beta0(9);
b5=beta0(10);
dd1=a1*sin(4.3945*dd2+b1)+a2*sin(4.3945*dd2+b2)+a3*sin(4.3945*dd2+b3)+a4*sin(4.3945*dd2+b4)+a5*sin(4.3945*dd2+b5);
文件名改为model.m,保持文件名和函数名一致,另外该该函数的内容整个都是错误的,建议采用
edit hougen
看一下正确定的应该是怎么写的吧
调用改为
betafit=nlinfit(dd2,dd1,'model',beta0);
从楼上写的程序看,楼主应该基本没有写过matlab程序,建议找本matlab入门的书籍先看看 楼上的高手,谢谢你的解答。但是我昨晚自己修改了一下我上面贴的程序,可以运行了,但是拟合出来的数据不对,不知道是何缘故?
可运行的程序如下:
首先编制非线性模型m文件(sta67_2m.m)[昨天我这个文件存错了地方,结果老是抱错,我现在是保存在运行目录下的]:
function dd1=model(beta0,dd2)
a=beta0(1);
b=beta0(2);
c=beta0(3);
d=beta0(4);
e=beta0(5);
f=beta0(6);
g=beta0(7);
h=beta0(8);
k=beta0(9);
l=beta0(10);
dd1=a*sin(2*pi*0.97656*dd2+b)+c*sin(2*pi*1.9531*dd2+d)+e*sin(2*pi*2.9297*dd2+f)+g*sin(2*pi*3.9063*dd2+h)+k*sin(2*pi*4.8828*dd2+l);
然后在命令栏里面输入:
yy=Data(2100*500:2103*500);dd1=yy';
x=0:0.002:3;dd2=x;
beta0=;
nlintool(dd2,dd1,'sta67_2m',beta0);
betafit=nlinfit(dd2,dd1,'sta67_2m',beta0);
betafit=0.039909 -35.47
-0.044785 0.075721
-0.13027 0.8733
0.32827 11.404
0.40317 -4.0571
然后我将实际dd1值的图形和拟合出来的dd1的图形进行对比(见附图1和附图2),从两图可以看出可以看出图形形状不一样且大小也差的很远,不知道这是怎么回事?
[ 本帖最后由 xinyuxf 于 2006-12-23 09:51 编辑 ] 估计是初值选择问题,这是个很头疼的事情,一般没有什么太好的办法解决
建议采用一些对初值不敏感的算法 请问有哪些命令对初值不敏感呢?
页:
[1]