zoukankan      html  css  js  c++  java
  • 最小二乘法

    最小二乘法(又称最小平方法)是一种数学优化技术。它通过最小化误差的平方和寻找数据的最佳函数匹配。

    利用最小二乘法可以简便地求得未知的数据,并使得这些求得的数据与实际数据之间误差的平方和为最小。

    最小二乘法还可用于曲线拟合

    其他一些优化问题也可通过最小化能量或最大化用最小二乘法来表达。

    简介

    高斯

    1801年,意大利天文学家朱赛普·皮亚齐发现了第一颗小行星谷神星。经过40天的跟踪观测后,由于谷神星运行至太阳背后,使得皮亚齐失去了谷神星的位置。随后全世界的科学家利用皮亚齐的观测数据开始寻找谷神星,但是根据大多数人计算的结果来寻找谷神星都没有结果。时年24岁的高斯也计算了谷神星的轨道。奥地利天文学家海因里希·奥尔伯斯根据高斯计算出来的轨道重新发现了谷神星。

    高斯使用的最小二乘法的方法发表于1809年他的著作《天体运动论》中,而法国科学家勒让德于1806年独立发现“最小二乘法”,但因不为时人所知而默默无闻。两人曾为谁最早创立最小二乘法原理发生争执。

    1829年,高斯提供了最小二乘法的优化效果强于其他方法的证明,见高斯-马尔可夫定理

    方法

    人们对由某一变量t 或多个变量t_{1}……t_{n} 构成的相关变量y感兴趣。如弹簧形变与所用的力相关,一个企业的盈利与其营业额投资收益原始资本有关。为了得到这些变量同y之间的关系,便用不相关变量去构建y,使用如下函数模型

    y_m = f(t_1,dots, t_q;x_1,dots,x_p),

    q个相关变量或p个附加的相关变量去拟和。

    通常人们将一个可能的、对不相关变量t的构成都无困难的函数类型称作函数模型(如抛物线函数或指数函数)。参数x是为了使所选择的函数模型同观测值y相匹配。(如在测量弹簧形变时,必须将所用的力与弹簧的膨胀系数联系起来)。其目标是合适地选择参数,使函数模型最好的拟合观测值。一般情况下,观测值远多于所选择的参数。

    其次的问题是怎样判断不同拟合的质量。高斯勒让德的方法是,假设测量误差的平均值为0。令每一个测量误差对应一个变量并与其它测量误差不相关(随机无关)。人们假设,在测量误差中绝对不含系统误差,它们应该是纯偶然误差,围绕真值波动。除此之外,测量误差符合正态分布,这保证了偏差值在最后的结果y上忽略不计。

    确定拟合的标准应该被重视,并小心选择,较大误差的测量值应被赋予较小的。并建立如下规则:被选择的参数,应该使算出的函数曲线与观测值之差的平方和最小。用函数表示为:

     min_{vec{x}} { sum_{i=1}^{n}(y_m - y_i)^2} .

    欧几里得度量表达为:

     min_{ vec{x} } | vec{y}_{m} ( vec{x} ) - vec{y} |_{2}  .

    最小化问题的精度,依赖于所选择的函数模型。

    线性函数模型

    典型的一类函数模型是线性函数模型。最简单的线性式是y = x_0 + x_1 t,写成行列式,为

     min_{x_0,x_1}left|egin{pmatrix}1 & t_1 \ vdots & vdots \ 1 & t_n  end{pmatrix} egin{pmatrix} x_0\ x_1end{pmatrix} - egin{pmatrix} y_1 \ vdots \ y_{n}end{pmatrix}
ight|_{2} = min_x|Ax-b|_2.

    直接给出该式的参数解:

    x_1 = frac{sum_{i=1}^n t_iy_i - n cdot ar t ar y}{sum_{i=1}^n t_i^2- n cdot (ar t)^2}x_0 = ar y - x_1 ar t

    其中ar t = frac{1}{n} sum_{i=1}^n t_i,为t值的算术平均值。也可解得如下形式:

    x_1 = frac{sum_{i=1}^n (t_i - ar t)(y_i - ar y)}{sum_{i=1}^n (t_i - ar t)^2}

    简单线性模型 y = x0 + x1t 的例子

    随机选定10艘战舰,并分析它们的长度与宽度,寻找它们长度与宽度之间的关系。由下面的描点图可以直观地看出,一艘战舰的长度(t)与宽度(y)基本呈线性关系。散点图如下:散点图

    以下图表列出了各战舰的数据,随后步骤是采用最小二乘法确定两变量间的线性关系。

    编号 长度 (m) 宽度 (m) ti - t yi - y


    i ti yi ti* yi* ti*yi* ti*ti* yi*yi*
    1 208 21.6 40.2 3.19 128.238 1616.04 10.1761
    2 152 15.5 -15.8 -2.91 45.978 249.64 8.4681
    3 113 10.4 -54.8 -8.01 438.948 3003.04 64.1601
    4 227 31.0 59.2 12.59 745.328 3504.64 158.5081
    5 137 13.0 -30.8 -5.41 166.628 948.64 29.2681
    6 238 32.4 70.2 13.99 982.098 4928.04 195.7201
    7 178 19.0 10.2 0.59 6.018 104.04 0.3481
    8 104 10.4 -63.8 -8.01 511.038 4070.44 64.1601
    9 191 19.0 23.2 0.59 13.688 538.24 0.3481
    10 130 11.8 -37.8 -6.61 249.858 1428.84 43.6921
    总和(Σ) 1678 184.1 0.0 0.00 3287.820 20391.60 574.8490


    仿照上面给出的例子

    ar t = frac {sum_{i=1}^n t_i}{n} = frac {1678}{10} = 167{.}8 并得到相应的ar y = 18{.}41.

    然后确定x1

    x_1 = frac{sum_{i=1}^n (t_i- ar {t})(y_i - ar y)}{sum_{i=1}^n (t_i- ar t)^2}
     = frac{3287{.}820} {20391{.}60} = 0{.}1612 ;,

    可以看出,战舰的长度每变化1m,相对应的宽度便要变化16cm。并由下式得到常数项x0

    x_0 = ar y - x_1 ar t = 18{.}41 - 0{.}1612 cdot 167{.}8 = -8{.}6394;,

    在这里随机理论不加阐述。可以看出点的拟合非常好,长度宽度的相关性大约为96.03%。 利用Matlab得到拟合直线: 最小二乘法Matlab拟合

    一般线性情况

    若含有更多不相关模型变量t_1, ..., t_q,可如组成线性函数的形式

    y(t_1,dots,t_q;x_0, x_1, dots, x_q )= x_0 + x_1 t_1 + cdots + x_q t_q

    线性方程组

     egin{matrix}x_0 + x_1 t_{11} + cdots + x_j t_{1j}+ cdots +x_q t_{1q} = y_1\x_0 + x_1 t_{21} + cdots + x_j t_{2j}+ cdots +x_q t_{2q} = y_2\vdots \x_0 + x_1 t_{i1} + cdots + x_j t_{ij}+ cdots +x_q t_{iq}= y_i\vdots\x_0 + x_1 t_{n1} + cdots + x_j t_{nj}+ cdots +x_q t_{nq}= y_nend{matrix}

    通常人们将tij记作数据矩阵 A,参数xj记做参数矢量x,观测值yi记作b,则线性方程组又可写成:

     egin{pmatrix}1 & t_{11} & cdots & t_{1j} cdots & t_{1q}\1 & t_{21} & cdots & t_{2j} cdots & t_{2q}\vdots \1 & t_{i1} & cdots & t_{ij} cdots & t_{iq}\vdots\1 & t_{n1} & cdots & t_{nj} cdots & t_{nq}end{pmatrix}cdotegin{pmatrix}x_0\x_1\x_2\vdots \x_j\vdots\x_qend{pmatrix}=egin{pmatrix}y_1\y_2\vdots \y_i\vdots\y_nend{pmatrix}Ax = b

    上述方程运用最小二乘法导出为线性平差计算的形式为:

    min_x|Ax-b|_2

    最小二乘法的解

    min_x left |oldsymbol{Ax}- oldsymbol{b} 
ight |_2,oldsymbol{A}inmathbf{C}^{m	imes n},oldsymbol{b}inmathbf{C}^{n}

    的特解为A广义逆矩阵b的乘积,这同时也是二范数极小的解,其通解为特解加上A零空间。证明如下:

    先将b拆成A的值域及其正交补两部分

    oldsymbol{b}=oldsymbol{b}_{1}+oldsymbol{b}_{2}
    oldsymbol{b}_{1}=oldsymbol{A}oldsymbol{A}^daggeroldsymbol{b}in Rleft(oldsymbol{A} 
ight)
    oldsymbol{b}_{2}=left(oldsymbol{I}- oldsymbol{A}oldsymbol{A}^dagger 
ight)oldsymbol{b}in Rleft(oldsymbol{A} 
ight)^{ot}

    所以oldsymbol{Ax}-oldsymbol{b}_{1}in Rleft(oldsymbol{A} 
ight),可得

    left | oldsymbol{Ax}- oldsymbol{b} 
ight |^{2}=left | oldsymbol{Ax}- oldsymbol{b}_{1} +left(-oldsymbol{b}_{2}
ight) 
ight |^{2}=left | oldsymbol{Ax}- oldsymbol{b}_{1} 
ight |^{2}+left |oldsymbol{b}_{2} 
ight |^{2}

    故当且仅当oldsymbol{x}oldsymbol{Ax}= oldsymbol{b}_{1} =oldsymbol{A}oldsymbol{A}^daggeroldsymbol{b}解时,oldsymbol{x}即为最小二乘解,即oldsymbol{x}=oldsymbol{A}^dagger oldsymbol{b}

    又因为

    Nleft(oldsymbol{A}
ight)=Nleft(oldsymbol{A}^dagger oldsymbol{A}
ight)=Rleft(oldsymbol{I}-oldsymbol{A}^dagger oldsymbol{A}
ight)=left{ left(oldsymbol{I}-oldsymbol{A}^dagger oldsymbol{A} 
ight) oldsymbol{h}:oldsymbol{h}inmathbf{C}^{n}  
ight}

    oldsymbol{Ax}=oldsymbol{A}oldsymbol{A}^daggeroldsymbol{b}的通解为

    oldsymbol{x}=oldsymbol{A}^daggeroldsymbol{b}+left(oldsymbol{I}-oldsymbol{A}^dagger oldsymbol{A} 
ight) oldsymbol{h}:oldsymbol{h}inmathbf{C}^{n}

    因为

    egin{align}left | oldsymbol{A}^daggeroldsymbol{b}
ight |^{2} & < left | oldsymbol{A}^daggeroldsymbol{b} 
ight |^{2}+ left | left(oldsymbol{I}-oldsymbol{A}^dagger oldsymbol{A} 
ight) oldsymbol{h} 
ight |^{2} \& = left | oldsymbol{A}^daggeroldsymbol{b} + left(oldsymbol{I}-oldsymbol{A}^dagger oldsymbol{A} 
ight) oldsymbol{h} 
ight |^{2},left(oldsymbol{I}-oldsymbol{A}^dagger oldsymbol{A} 
ight) oldsymbol{h}
eqoldsymbol{0} \end{align}

    所以oldsymbol{A}^dagger oldsymbol{b}又是二范数极小的最小二乘解。

  • 相关阅读:
    群辉:服务器错误 错误代码38
    wireshark filter manualpage
    收集下shell使用笔记
    Android kernel LOGO的更换方法
    java实现截屏
    [转]android4.0.3 修改启动动画和开机声音
    博客搬迁
    idea 2017.3创建springboot项目报无效的源发行版: 1.8或者Unsupported major.minor version 52.0的解决方案
    关于mybatis查询集合返回为[null]的问题
    关于mybatis中resultType返回null的问题
  • 原文地址:https://www.cnblogs.com/cl1024cl/p/6205267.html
Copyright © 2011-2022 走看看