函数逼近与曲线(面)拟合的MATLAB程序

发布时间:2021-06-06

函数逼近与曲线(面)拟合的MATLAB程序

7.1 曲线拟合、误差及其MATLAB程序

例7.1.1 已知函数y f(x) 5x3 14x 7sin2(2 x)和一组数据(xi,yi)列入表7–1中,比较最大误差,平均误差,均方根误差和误差平方和.

表7–1 例7.1.1的一组数据(

x,y)

解 由给定的函数和数据,在MATLAB工作窗口输入

>> x=[-2.5,-1.7,-1.1,-0.8,0,0.1,0.5,3.6]; n=length(x);

y=[-43.50 5.69 11.34 14.16 0 1.02 -6.37 185.84];

f=5.*x.^3-14.*x+7.*(sin(2*pi*x)).^2; fy=abs(f-y);

fy2=fy.^2; [x',y',f',fy',fy2'], Ew=max(fy),

E1=sum(fy)/n, E2=sqrt((sum(fy2))/n), E=sum(fy2)

运行后屏幕显示如下

x y f fy fy2

-2.5000 -43.5000 -43.1250 0.3750 0.1406

-1.7000 5.6900 5.5666 0.1234 0.0152

-1.1000 11.3400 11.1634 0.1766 0.0312

-0.8000 14.1600 14.9716 0.8116 0.6586

0 0 0 0 0

0.1000 1.0200 1.0234 0.0034 0.0000

0.5000 -6.3700 -6.3750 0.0050 0.0000

3.6000 185.8400 185.2984 0.5416 0.2933

Ew = E1 = E2 = E =

0.8116 0.2546 0.3773 1.1390

7.2 曲线拟合的线性最小二乘法及其MATLAB程序

例7.2.1 给出一组数据点(xi,yi)列入表7–2中,试用线性最小二乘法求拟合曲线,并用(7.2),(7.3)和(7.4)式估计其误差,作出拟合曲线.

表7–2 例7.2.1的一组数据(

x,y)

解 (1)在MATLAB工作窗口输入程序

>> x=[-2.5 -1.7 -1.1 -0.8 0 0.1 1.5 2.7 3.6];

y=[-192.9 -85.50 -36.15 -26.52 -9.10 -8.43 -13.12 6.50 68.04];

plot(x,y,'r*'),

legend('实验数据(xi,yi)')

xlabel('x'), ylabel('y'),

title('例7.2.1的数据点(xi,yi)的散点图')

运行后屏幕显示数据的散点图(略).

(3)编写下列MATLAB程序计算f(x)在(xi,yi)处的函数值,即输入程序

>> syms a1 a2 a3 a4

x=[-2.5 -1.7 -1.1 -0.8 0 0.1 1.5 2.7 3.6];

fi=a1.*x.^3+ a2.*x.^2+ a3.*x+ a4

运行后屏幕显示关于a1,a2, a3和a4的线性方程组

函数逼近与曲线(面)拟合的MATLAB程序.doc 将本文的Word文档下载到电脑

精彩图片

热门精选

大家正在看

× 游客快捷下载通道(下载后可以自由复制和排版)

限时特价:7 元/份 原价:20元

支付方式:

开通VIP包月会员 特价:29元/月

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219