MATLAB数据拟合(二)

来源:互联网 发布:传智播客云计算大数据 编辑:程序博客网 时间:2024/06/05 10:17

转自飞扬博客


4.         多项式曲线拟合的评价和置信区间函数:polyconf( )


调用格式:  [Y,DELTA]=polyconf(p,x,s)


                     [Y,DELTA]=polyconf(p,x,s,alpha)


说明:[Y,DELTA]=polyconf(p,x,s)使用polyfit函数的选项输出s给出Y的95%置信区间Y DELTA。它假设polyfit函数数据输入的误差是独立正态的,并且方差为常数。1-alpha为置信度。


例4:给出上面例1的预测值及置信度为90%的置信区间。


程序:   x=0:.1:1;


        y=[.3 .5 1 1.4 1.6 1.9 .6 .4 .8 1.5 2]


        n=3;


        [p,s]=polyfit(x,y,n)


        alpha=0.05;


       [Y,DELTA]=polyconf(p,x,s,alpha)


       结果:  


 p =


   16.7832  -25.7459   10.9802   -0.0035



s =


   R: [4x4 double]
  df: 7
normr: 1.1406



Y =


  Columns 1 through 9


   -0.0035    0.8538    1.2970    1.4266    1.3434    1.1480    0.9413    0.8238    0.8963


  Columns 10 through 11


    1.2594    2.0140


5.         稳健回归函数:robust( )


稳健回归是指此回归方法相对于其他回归方法而言,受异常值的影响较小。


调用格式:  b=robustfit(x,y)


                     [b,stats]=robustfit(x,y)


                     [b,stats]=robustfit(x,y,’wfun’,tune,’const’)


说明:b返回系数估计向量;stats返回各种参数估计;’wfun’指定一个加权函数;tune为调协常数;’const’的值为’on’(默认值)时添加一个常数项;为’off ’时忽略常数项。


例5:演示一个异常数据点如何影响最小二乘拟合值与稳健拟合。首先利用函数y=10-2x加上一些随机干扰的项生成数据集,然后改变一个y的值形成异常值。调用不同的拟合函数,通过图形观查影响程度。


程序:x=(1:10)’;


y=10-2*x+randn(10,1);


y(10)=0;


bls=regress(y,[ones(10,1) x]) %线性拟合


brob=robustfit(x,y) %稳健拟合


scatter(x,y)


hold on


plot(x,bls(1)+bls(2)*x,’:’)


plot(x,brob(1)+brob(2)*x,’r‘)


结果 : bls =


                    8.4452


                   -1.4784


brob =


                   10.2934


                   -2.0006


MATLAB插值与拟合 - 飞扬 Youth - 浇灌一处绿色的风景


 


分析:稳健拟合(实线)对数据的拟合程度好些,忽略了异常值。最小二乘拟合(点线)则受到异常值的影响,向异常值偏移。


6.         向自定义函数拟合


对于给定的数据,根据经验拟合为带有待定常数的自定义函数。


所用函数:nlinfit( )


调用格式:  [beta,r,J]=nlinfit(X,y,’fun’,betao)


说明:beta返回函数’fun’中的待定常数;r表示残差;J表示雅可比矩阵。X,y为数据;‘fun’自定义函数;beta0待定常数初值。


例6:在化工生产中获得的氯气的级分y随生产时间x下降,假定在x≥8时,y与x之间有如下形式的非线性模型:


      


现收集了44组数据,利用该数据通过拟合确定非线性模型中的待定常数。


                                                                 y


           0.49               16           0.43               28           0.41


           0.49               18           0.46               28           0.40


10           0.48               18           0.45               30           0.40


10           0.47               20           0.42               30           0.40


10           0.48               20           0.42               30           0.38


10           0.47               20           0.43               32           0.41


12           0.46               20           0.41               32           0.40


12           0.46               22           0.41               34           0.40


12           0.45               22           0.40               36           0.41


12           0.43               24           0.42               36           0.36


14           0.45               24           0.40               38           0.40


14           0.43               24           0.40               38           0.40


14           0.43               26           0.41               40           0.36


16           0.44               26           0.40               42           0.39


16           0.43               26           0.41


       首先定义非线性函数的m文件:fff6.m


function yy=model(beta0,x)


  a=beta0(1);


  b=beta0(2);


  yy=a+(0.49-a)*exp(-b*(x-8));


       程序:


x=[8.00 8.00 10.00 10.00 10.00 10.00 12.00 12.00 12.00 14.00 14.00 14.00... 


     16.00 16.00 16.00 18.00 18.00 20.00 20.00 20.00 20.00 22.00 22.00 24.00...  


     24.00 24.00 26.00 26.00 26.00 28.00 28.00 30.00 30.00 30.00 32.00 32.00...


     34.00 36.00 36.00 38.00 38.00 40.00 42.00]';


   y=[0.49 0.49 0.48 0.47 0.48 0.47 0.46 0.46 0.45 0.43 0.45 0.43 0.43 0.44 0.43...


     0.43 0.46 0.42 0.42 0.43 0.41 0.41 0.40 0.42 0.40 0.40 0.41 0.40 0.41 0.41...


     0.40 0.40 0.40 0.38 0.41 0.40 0.40 0.41 0.38 0.40 0.40 0.39 0.39]';


     beta0=[0.30 0.02];


betafit = nlinfit(x,y,'sta67_1m',beta0)


结果:betafit =


                0.3896


0.1011


       即:a=0.3896 ,b=0.1011 拟合函数为:


0 0
原创粉丝点击