一元线性回归分析及java实现

本文深入探讨了一元线性回归分析,包括最小二乘法原理、正规方程组及其统计学原理,并提供了Java实现一元线性回归算法的详细步骤和代码示例。通过实例展示了如何利用回归方程进行数据预测。
摘要由CSDN通过智能技术生成

一元线性回归分析是处理两个变量之间关系的最简单模型,它所研究的对象是两个变量之间的线性相关关系。通过对这个模型的讨论,我们不仅可以掌握有关一元线性回归的知识,而且可以从中了解回归分析方法的基本思想、方法和应用。

 一、问题的提出

 例2-1-1  为了研究氮含量对铁合金溶液初生奥氏体析出温度的影响,测定了不同氮含量时铁合金溶液初生奥氏体析出温度,得到表2-1-1给出的5组数据。

表2-1-1   氮含量与灰铸铁初生奥氏体析出温度测试数据

    如果把氮含量作为横坐标,把初生奥氏体析出温度作为纵坐标,将这些数据标在平面直角坐标上,则得图2-1-1,这个图称为散点图。

从图2-1-1可以看出,数据点基本落在一条直线附近。这告诉我们,变量X与Y的关系大致可看作是线性关系,即它们之间的相互关系可以用线性关系来描述。但是由于并非所有的数据点完全落在一条直线上,因此X与Y的关系并没有确切到可以唯一地由一个X值确定一个Y值的程度。其它因素,诸如其它微量元素的含量以及测试误差等都会影响Y的测试结果。如果我们要研究X与Y的关系,可以作线性拟合

           (2-1-1)

 我们称(2-1-1)式为回归方程,a与b是待定常数,称为回归系数。从理论上讲,(2-1-1)式有无穷多组解,回归分析的任务是求出其最佳的线性拟合。

 二、最小二乘法原理

 如果把用回归方程 计算得到的 i值(i=1,2,…n)称为回归值,那么实际测量值yi与回归值 i之间存在着偏差,我们把这种偏差称为残差,记为ei(i=1,2,3,…,n)。这样,我们就可以用残差平方和来度量测量值与回归直线的接近或偏差程度。残差平方和定义为:

     (2-1-2)

所谓最小二乘法,就是选择a和b使Q(a,b)最小,即用最小二乘法得到的回归直线 是在所有直线中与测量值残差平方和Q最小的一条。由(2-1-2)式可知Q是关于a,b的二次函数,所以它的最小值总是存在的。下面讨论的a和b的求法。

三、正规方程组

根据微分中求极值的方法可知,Q(a,b)取得最小值应满足

                                (2-1-3)

由(2-1-2)式,并考虑上述条件,则

            (2-1-4)

(2-1-4)式称为正规方程组。解这一方程组可得

                       (2-1-5)

   其中

                       (2-1-6)

   (2-1-7)

    式中,Lxy称为xy的协方差之和,Lxx称为x的平方差之和。

如果改写(2-1-1)式,可得

                      (2-1-8)

    或

                        (2-1-9)

 由此可见,回归直线是通过点 的,即通过由所有实验测量值的平均值组成的点。从力学观点看, 即是N个散点 的重心位置。

 现在我们来建立关于例1的回归关系式。将表2-1-1的结果代入(2-1-5)式至(2-1-7)式,得出

a=1231.65

b=-2236.63

 因此,在例1中灰铸铁初生奥氏体析出温度(y)与氮含量(x)的回归关系式为

y=1231.65-2236.63x

 

 四、一元线性回归的统计学原理

 如果X和Y都是相关的随机变量,在确定x的条件下,对应的y值并不确定,而是形成一个分布。当X取确定的值时,Y的数学期望值也就确定了,因此Y的数学期望是x的函数,即

E(Y|X=x)=f(x)                  (2-1-10)

 这里方程f(x)称为Y对X的回归方程。如果回归方程是线性的,则

E(Y|X=x)=α+βx                (2-1-11)

 或

Y=α+βx+ε                    (2-1-12)

 其中

     ε―随机误差

 从样本中我们只能得到关于特征数的估计,并不能精确地求出特征数。因此只能用f(x)的估计式   来取代(2-1-11)式,用参数a和b分别作为α和β的估计量。那么,这两个估计量是否能够满足要求呢?

 

 1. 无偏性

 把(x,y)的n组观测值作为一个样本,由样本只能得到总体参数α和β的估计值。可以证明,当满足下列条件:

 (1)(xi,yi)是n个相互独立的观测值

 (2)εi是服从 分布的随机变量

 则由最小二乘法得到的a与b分别是总体参数α和β的无偏估计,即

E(a)= α

E(b)=β

    由此可推知

E( )=E(y)

    即y是回归值 在某点的数学期望值。

 2. a和b的方差

 可以证明,当n组观测值(xi,yi)相互独立,并且D(yi)=σ2,时,a和b的方差为

                               (2-1-13)

                  (2-1-14)

以上两式表明,a和b的方差均与xi的变动有关,xi分布越宽,则a和b的方差越小。另外a的方差还与观测点的数量有关,数据越多,a的方差越小。因此,为提高估计量的准确性,xi的分布应尽量宽,观测点数量应尽量多。



Java实现

1、定义一个DataPoint类,对X和Y坐标点进行封装:


  1. /** 
  2.  * File        : DataPoint.java 
  3.  * Author      : zhouyujie 
  4.  * Date        : 2012-01-11 16:00:00 
  5.  * Description : Java实现一元线性回归的算法,座标点实体类,(可实现统计指标的预测) 
  6.  */  
  7. package com.zyujie.dm;  
  8.   
  9. public class DataPoint {  
  10.   
  11.     /** the x value */  
  12.     public float x;  
  13.   
  14.     /** the y value */  
  15.     public float y;  
  16.   
  17.     /** 
  18.      * Constructor. 
  19.      *  
  20.      * @param x 
  21.      *            the x value 
  22.      * @param y 
  23.      *            the y value 
  24.      */  
  25.     public DataPoint(float x, float y) {  
  26.         this.x = x;  
  27.         this.y = y;  
  28.     }  
  29. }  


2、下面是算法实现回归线:

[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. /** 
  2.  * File        : DataPoint.java 
  3.  * Author      : zhouyujie 
  4.  * Date        : 2012-01-11 16:00:00 
  5.  * Description : Java实现一元线性回归的算法,回归线实现类,(可实现统计指标的预测) 
  6.  */  
  7. package com.zyujie.dm;  
  8.   
  9. import java.math.BigDecimal;  
  10. import java.util.ArrayList;  
  11.   
  12. public class RegressionLine // implements Evaluatable  
  13. {  
  14.     /** sum of x */  
  15.     private double sumX;  
  16.   
  17.     /** sum of y */  
  18.     private double sumY;  
  19.   
  20.     /** sum of x*x */  
  21.     private double sumXX;  
  22.   
  23.     /** sum of x*y */  
  24.     private double sumXY;  
  25.   
  26.     /** sum of y*y */  
  27.     private double sumYY;  
  28.   
  29.     /** sum of yi-y */  
  30.     private double sumDeltaY;  
  31.   
  32.     /** sum of sumDeltaY^2 */  
  33.     private double sumDeltaY2;  
  34.   
  35.     /** 误差 */  
  36.     private double sse;  
  37.   
  38.     private double sst;  
  39.   
  40.     private double E;  
  41.   
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值