《第七章 数据的曲线拟合席优秀课件.ppt》由会员分享,可在线阅读,更多相关《第七章 数据的曲线拟合席优秀课件.ppt(26页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第七章 数据的曲线拟合席第1页,本讲稿共26页1 1、联系、联系都是根据实际中一组已知数据来构造一个能够反映数据变化都是根据实际中一组已知数据来构造一个能够反映数据变化规律的近似函数的方法。规律的近似函数的方法。2 2、区别、区别插值问题插值问题不一定得到近似函数的表达形式,仅通过插值不一定得到近似函数的表达形式,仅通过插值方法找到未知点对应的值。方法找到未知点对应的值。数据拟合数据拟合要求得到一个具体要求得到一个具体的近似函数的表达式。的近似函数的表达式。拟合模型可以分为直线拟合、曲线拟合和观察数据拟合模型可以分为直线拟合、曲线拟合和观察数据修匀。修匀。插值与插值与拟合的区别和联系拟合的区别
2、和联系:第2页,本讲稿共26页一、直线拟合一、直线拟合若用线性函数拟合如下数据:若用线性函数拟合如下数据:线性函数表示为:线性函数表示为:其中其中 为待定系数。为待定系数。拟合直线称为拟合直线称为回归直线回归直线。第3页,本讲稿共26页 由于数据节点数大于未知数由于数据节点数大于未知数(即待定系数即待定系数)的个数的个数2,直线不可能经过每个点,但是直线与数据的偏差一定要达直线不可能经过每个点,但是直线与数据的偏差一定要达到最小。到最小。直线与点的偏离程度(即残差)直线与点的偏离程度(即残差)定义为:定义为:残差的平方和为:残差的平方和为:第4页,本讲稿共26页要使要使 R 达到最小,达到最小
3、,令令矩阵形式:矩阵形式:“线性最小二乘法线性最小二乘法”第5页,本讲稿共26页确定系数的另一种方法是直接求解超定线性方程组:确定系数的另一种方法是直接求解超定线性方程组:其中其中方程组两边同时左乘方程组两边同时左乘 ,得常规方程组:,得常规方程组:第6页,本讲稿共26页求解:求解:在在MATLAB中,也可直接求解超定方程组的解:中,也可直接求解超定方程组的解:c=A y%可求得最小二乘解可求得最小二乘解或已知数据点或已知数据点 x 与与 y,用用polyfit命令命令c=polyfit(x,y,1)第7页,本讲稿共26页例例1 求拟合下列数据点的直线。求拟合下列数据点的直线。x=0.1 0.
4、4 0.5 0.7 0.7 0.9;y=0.61 0.92 0.99 1.52 1.47 2.03;c=polyfit(x,y,1)c=1.7646 0.2862即线性函数即线性函数g(x)=1.7646x+0.2862第8页,本讲稿共26页A=x ones(6,1);c=(A*A)(A*y)c=1.7646 0.2862c=Ayc=1.7646 0.2862第9页,本讲稿共26页绘图程序:绘图程序:x=0.1 0.4 0.5 0.7 0.7 0.9;y=0.61 0.92 0.99 1.52 1.47 2.03;c=polyfit(x,y,1);y1=polyval(c,x);plot(x,
5、y,.,x,y1)gtext(y=1.7646x+0.2862);xlabel(X);ylabel(Y);第10页,本讲稿共26页二、非线性曲线拟合二、非线性曲线拟合对一组数据,若做拟合幂函数:对一组数据,若做拟合幂函数:为确定待定系数为确定待定系数 ,取自然对数:,取自然对数:取:取:则:则:问题简化为线性回归,拟合数据点为:问题简化为线性回归,拟合数据点为:然后确定然后确定第11页,本讲稿共26页例例2 做下列数据点的幂函数拟合。做下列数据点的幂函数拟合。c=polyfit(log(x),log(y),1)c=0.2093 1.8588结果:结果:所以所以第12页,本讲稿共26页第13页,
6、本讲稿共26页x=0.15 0.4 0.6 1.01 1.5 2.2 2.4 2.7 2.9 3.5 3.8 4.4 4.6 5.1 6.6 7.6;y=4.4964 5.1284 5.6931 6.2884 7.0989 7.5507 7.5106 8.0756 7.8708 8.2403 8.5303 8.7394 8.9981 9.1450 9.5070 9.9115;c=polyfit(log(x),log(y),1);alfa=c(1);beta=exp(c(2);y1=beta*x.alfa;subplot(2,2,1)plot(x,y,+)xlabel(X);ylabel(Y);
7、第14页,本讲稿共26页subplot(2,2,2)plot(x,y,+)hold onloglog(x,y)xlabel(X);ylabel(Y);title(a)Loglog plot of y vs x,Color,r)subplot(2,2,3)plot(log(x),log(y),+,log(x),log(y)xlabel(log(X);ylabel(log(Y);title(b)Linear plot of log(y)vs log(x),Color,r);subplot(2,2,4)plot(x,y,+,x,y1)xlabel(X);ylabel(Y);title(c)Linea
8、r plot of y vs x,Color,r);hold off第15页,本讲稿共26页例例3 已知已知 x 0 1 2 3 4 y 1.5 2.5 3.5 5.0 7.5利用利用最小二乘法最小二乘法求求指数拟合指数拟合 y=c e ax 方法方法1 令令求求a,c 使使 S(a,c)=min%非线性最小二乘非线性最小二乘方法方法2非线性模型的线性化处理非线性模型的线性化处理 y=c e a x 取自然对数取自然对数 ln(y)=a x+ln(c)得得,Y=a x+b%线性最小二乘线性最小二乘确定了确定了a,b之后,可得之后,可得c=eb第16页,本讲稿共26页MATLAB提供了求提供了求
9、非线性最小二乘拟合非线性最小二乘拟合的函数:的函数:lsqcurvefit:输入格式为输入格式为:(1)x=lsqcurvefit(fun,x0,xdata,ydata);(2)x=lsqcurvefit(fun,x0,xdata,ydata,options);(3)x=lsqcurvefit(fun,x0,xdata,ydata,options,grad);(4)x,options=lsqcurvefit(fun,x0,xdata,ydata,);(5)x,options,funval=lsqcurvefit(fun,x0,xdata,ydata,);(6)x,options,funval,
10、Jacob=lsqcurvefit(fun,x0,xdata,ydata,);其中,其中,fun-事先定义的非线性拟合函数事先定义的非线性拟合函数x0-迭代初值迭代初值xdata,ydata-已知数据点已知数据点第17页,本讲稿共26页x=0 1 2 3 4;y=1.5 2.5 3.5 5.0 7.5;c=lsqcurvefit(fff,1;2,x,y)%非线性最小二乘法非线性最小二乘法yy=c(1)*exp(c(2)*x);c1=polyfit(x,log(y),1);%线性化方法线性化方法y1=exp(c1(2)*exp(x*c1(1);plot(x,yy,b,x,y1,r)legend(
11、最小二乘法最小二乘法,线性化方法线性化方法)xlabel(X);ylabel(Y);function y=fff(c,x)y=c(1)*exp(c(2)*x);y=c e ax Y=a x+b,c=eb第18页,本讲稿共26页三、高次多项式曲线拟合三、高次多项式曲线拟合最小二乘的思想可以推广到高次多项式拟合。最小二乘的思想可以推广到高次多项式拟合。设设 n 次多项式:次多项式:曲线与数据点的残差:曲线与数据点的残差:记:记:为使为使 R 最小,令最小,令第19页,本讲稿共26页即:即:矩阵形式为:矩阵形式为:第20页,本讲稿共26页 另一种推导格式:另一种推导格式:将其写为超定方程:将其写为超
12、定方程:其中:其中:当当 时,方程为超定的,可求其最小二乘解:时,方程为超定的,可求其最小二乘解:c=Ay 或或 c=polyfit(x,y,n)第21页,本讲稿共26页例例4 用二次多项式拟合下列数据:用二次多项式拟合下列数据:x=0.1,0.4,0.5,0.7,0.7,0.9;y=0.61,0.92,0.99,1.52,1.47,2.03;cc=polyfit(x,y,2);xx=0:0.1:1;yy=polyval(cc,xx);plot(xx,yy,x,y,x)axis(0,1,0,3)xlabel(X);ylabel(Y)第22页,本讲稿共26页第23页,本讲稿共26页四、函数线性组
13、合曲线拟合法四、函数线性组合曲线拟合法 拟合数据时,也可用已知函数的线性组合,形式为:拟合数据时,也可用已知函数的线性组合,形式为:其中其中 是已知函数是已知函数,是待定系是待定系数,数,n是所用函数个数。是所用函数个数。用上式拟合数据,得超定方程:用上式拟合数据,得超定方程:第24页,本讲稿共26页例例5 确定拟合函数确定拟合函数的系数,拟合的数据如下。的系数,拟合的数据如下。第25页,本讲稿共26页data=0.1 0.61;0.4 0.92;0.5 0.99;0.7 1.52;0.7 1.47;0.9 2.03;x=data(:,1);y=data(:,2);A(:,1)=ones(size(x);A(:,2)=x;A(:,3)=sin(x);A(:,4)=exp(x);c=Ay;xx=0:0.01:1;g=c(1)*ones(size(xx)+c(2)*xx+c(3)*sin(xx)+c(4)*exp(xx);plot(x,y,*,xx,g);xlabel(x);ylabel(y)axis(square);axis(0,1,0,3)第26页,本讲稿共26页
限制150内