无论是使用线性拟合还是非线性拟合,最小二乘法都是使用它们的基础。关于最小二乘法的数学原理可以给出很多很好的解释,比如可以直接使用多元函数极值的观点,也可以使用线性代数中向量到子空间距离的观点。因为第二种方法比较直观,所以我将用第二种方法来描述最小二乘法这样显得更加直观易懂,而用第一种方法来进行验证。

  1、线性代数方法的描述

   为了表述方便,这里进行一些符号的说明,如下图所示:

python 非线性最小二乘 约束条件_python 非线性最小二乘 约束条件

图1

(1) A=[a1, a2]  

(2) p是基向量a1,a2的组合p=x1'a1+x2'a2=Ax'

(3) e=b-p

  2.数学模型(At即为A的转置,x'为x拔)

  

python 非线性最小二乘 约束条件_最小二乘法_02

图2

  如上图2所示我们解非线性齐次方程Ax=b,显然向量b并不在A的列空间(Col Space)中,即我们无法用A的列向量或是它们的线性组合来表示b,也就是该方程无解。

  虽然我们无法对上面的方程求解x,但是我们可以求其最优解(最近似解)x',由上图2我们可以看出b在Col Space上的投影p是A的列空间可以表示的最接近的向量。

  下面我们进行下数学描述:

  (1) 令p=Ax',由图1的正交性可以得出,a1t(b-Ax')=0,a2t(b-Ax')=0

  (2) [a1t ; a2t](b-Ax')=0 即At(b-Ax')=0

  (3) 整理(2)式得AtAx'=Atb  --最小二乘法核心公式

  (4) x'=(AtA) \ Atb --这里为Matlab写法

对(3)进行下简单说明,本来Ax=b是无解的,但是通过对方程两边左乘At,我们可以得到最优解x‘。

  3. 一个实例

python 非线性最小二乘 约束条件_最小二乘法_03

图2

  求Ax=b的最优解

  (1) 绘出一条直接y=C+Dt来拟合图上的三个点(1,1),(2,2),(3,2)

  (2) C+D=1,C+2D=2,C+3D=2 =>[1 1 ; 1 2 ; 1 3][C ; D]=[1 ; 2 ; 2]

  (3) 求解最优解x’=[C' ; D'] 

        AtAx'=Atb =>  AtAx'=[1 1 1;1 2 3] [1 1 ; 1 2 ; 1 3][C' ; D']=[3C' 6D' ; 6C' 14D']

                                 Atb=[1 1 1;1 2 3][1;2;2]=[5;11]

        因此3C'+6D'=5

                6C'+14D'=11

         =>C'=2/3  D'=1/2 即所求拟合曲线为y=2/3+1/2t   

 4. 多元函数极值验证

 这里对3进行验证,由图2,既然是最优解

 (1)   使得||Ax-b||^2最小,即||Ax-b||^2=||e||^2=0

 (2) 即使e1^2+e2^2+e3^2=f(C,D)(C+D-1)^2+(C+2D-2)^2+(C+3D-2)^2=0

 (3) 求C,D使得f(C,D)=0,因此对f分别对C,D求偏导等于0,同样得到3C+6D=5,6C+14D=11,证毕。

5. 编写一个Matlab程序来理解最小二乘法的线性与非线性拟合

求数据

x

-3

-2

-1

0

1

2

3

y

4

2

3

0

-1

-2

-5

的最小二乘拟合

(1) 用y=a0+a1*x+a2*x^2拟合


%最小二乘拟合的主函数
clear
x=[-3 -2 -1 0 1 2 3]';
y=[4 2 3 0 -1 -2 -5]';
% 得到线性方程的系数矩阵
a=[
    zx_nh_f(x(1))
    zx_nh_f(x(2))
    zx_nh_f(x(3))
    zx_nh_f(x(4))
    zx_nh_f(x(5))
    zx_nh_f(x(6))
    zx_nh_f(x(7))
    ];
b=y;
A=a'*a;
B=a'*b;
c=A\B
%得到拟合函数
x_n=-3:0.02:3;
y_n=c(1)*1+c(2)*x_n+c(3)*x_n.^2;
plot(x,y,'*',x_n,y_n)
grid
function f = zx_nh_f( x )  %子函数zx_nh_f
%ZX_NH_F Summary of this function goes here
%   Detailed explanation goes here
f(1)=1;
f(2)=x;
f(3)=x^2;
end


得到结果

c =
    0.6667
   -1.3929
   -0.1310

python 非线性最小二乘 约束条件_python 非线性最小二乘 约束条件_04


(2) 用y=a0+a1*x拟合

主函数和子函数稍作变化


y_n=c(1)*1+c(2)*x_n; %主函数
%f(3)=x^2;  %删掉


python 非线性最小二乘 约束条件_拟合_05



引用:

《MATLAB数值分析与应用_宋叶志》



关于过拟合的概念之前只是草草看过,没深入理解,准备下面有时间再好好看看,所以这里我就先不往下面分析了,研究后再写写。假期后面要做FPGA的项目了,准备把FPGA的项目进展也写写~