最小二乘问题详解4:非线性最小二乘

79 阅读5分钟

1. 引言

在论述最小二乘问题的时候,很多文章都喜欢用拟合直线来举例,但是在现实中像拟合直线这样的线性最小二乘问题往往不是常态,现实世界中更多是像投影成像这种非线性最小二乘问题。在本文中,我们就讲解一下非线性最小二乘问题。

不过,在继续阅读本文之前,一定要先理解之前的3篇文章,因为线性最小二乘是求解非线性最小二乘问题的基础:

  1. 《最小二乘问题详解1:线性最小二乘》
  2. 《最小二乘问题详解2:线性最小二乘求解》
  3. 《最小二乘问题详解3:线性最小二乘实例》

2. 定义

具体来说,非线性最小二乘的目标就是找到一组参数 θ\theta,使得非线性模型 f(x;θ)f(x; \theta) 最好地拟合观测数据。非线性最小二乘模型通常使用如下公式来表达:

y=f(x;θ)+ε\mathbf{y} = f(\mathbf{x}; \theta) + \varepsilon

其中:

  • xRn\mathbf{x} \in \mathbb{R}^n:输入变量(如坐标、时间等)
  • θRp\theta \in \mathbb{R}^p:待估计参数向量
  • f:Rd×RpRmf: \mathbb{R}^d \times \mathbb{R}^p \to \mathbb{R}^m非线性向量值函数
  • ε\varepsilon:观测噪声
  • yRm\mathbf{y} \in \mathbb{R}^m:观测输出

我们有 nn 组数据:

{(xi,yi)}i=1n\{ (\mathbf{x}_i, \mathbf{y}_i) \}_{i=1}^n

同样的,非线性最小二乘的目标是最小化残差平方和

minθS(θ)=minθi=1nri(θ)2=minθr(θ)2\boxed{ \min_{\theta} S(\theta) = \min_{\theta} \sum_{i=1}^n \| \mathbf{r}_i(\theta) \|^2 = \min_{\theta} \| \mathbf{r}(\theta) \|^2 }

其中:

  • ri(θ)=yif(xi;θ)\mathbf{r}_i(\theta) = \mathbf{y}_i - f(\mathbf{x}_i; \theta):第 ii 个样本的残差向量
  • r(θ)=[r1T,r2T,,rnT]T\mathbf{r}(\theta) = [\mathbf{r}_1^T, \mathbf{r}_2^T, \dots, \mathbf{r}_n^T]^T:所有残差拼成的长向量,维度 N=nmN = n \cdot m

那么非线性最小二乘能不能像线性那样直接求解呢?显然是不行的。因为在线性情况下,残差是 r=Aθb\mathbf{r} = A\theta - b,目标函数是 Aθb2\|A\theta - b\|^2,这是一个二次函数,所以有闭式解 (ATA)1ATb(A^T A)^{-1} A^T b。但在非线性情况下,r(θ)2\| \mathbf{r}(\theta) \|^2 是一个非凸、非二次函数,无法直接求逆,也就无法计算出闭式解。更直观的说,通过非线性函数f(x;θ)f(\mathbf{x}; \theta)是无法写成类似设计矩阵Aθ=bA\theta=b这样的线性方程组的。

一种求解的思路是局部线性化(Local Linearization)。虽然f(x;θ)f(\mathbf{x}; \theta)是非线性的,但是当前估计θk\theta_k附近,我们可以用泰勒展开一阶近似

f(xi;θ)f(xi;θk)+Ji(θk)(θθk)f(x_i; \theta) \approx f(x_i; \theta_k) + J_i(\theta_k) (\theta - \theta_k)

其中:

  • Ji(θk)=f(xi;θ)θθ=θkJ_i(\theta_k) = \frac{\partial f(x_i; \theta)}{\partial \theta} \big|_{\theta = \theta_k}雅可比矩阵的第 ii
  • J(θk)J(\theta_k)n×pn \times p 矩阵(nn 已知参数,pp 待定参数)

所以残差近似为:

r(θ)r(θk)+J(θk)(θθk)\mathbf{r}(\theta) \approx \mathbf{r}(\theta_k) + J(\theta_k) (\theta - \theta_k)

这样就得到了一个关于 θ\theta 的线性模型

3. 雅可比矩阵

在进行正式求解之前,我们先理解一下雅可比矩阵(Jacobian Matrix),因为它在最小二乘问题中经常被提到。其实从泰勒公式出发也很好理解,一元函数泰勒公式的一阶项是该函数的导数,那么多元函数泰勒公式的一阶项就是该函数的偏导。对于非线性最小二乘问题来说,一阶项雅可比矩阵J(θ)J(\theta) 是残差向量 r(θ)\mathbf{r}(\theta) 对参数 θ\theta 的一阶偏导数组成的矩阵。

J(θ)J(\theta)N×pN \times p 矩阵,其中 N=i=1nmiN = \sum_{i=1}^n m_i(通常mim_i是一个固定值mm),即:

J(θ)=[r1θTr2θTrnθT]RN×pJ(\theta) = \begin{bmatrix} \frac{\partial \mathbf{r}_1}{\partial \theta^T} \\ \frac{\partial \mathbf{r}_2}{\partial \theta^T} \\ \vdots \\ \frac{\partial \mathbf{r}_n}{\partial \theta^T} \end{bmatrix} \in \mathbb{R}^{N \times p}

其中:

  • riθT\frac{\partial \mathbf{r}_i}{\partial \theta^T} 是一个 m×pm \times p 矩阵,表示第 ii 个样本的残差对参数的梯度。

由于 ri=yif(xi;θ)\mathbf{r}_i = \mathbf{y}_i - f(\mathbf{x}_i; \theta),且 yi\mathbf{y}_i 是常数,所以:

riθT=f(xi;θ)θT\frac{\partial \mathbf{r}_i}{\partial \theta^T} = - \frac{\partial f(\mathbf{x}_i; \theta)}{\partial \theta^T}

因此:

J(θ)=[f(x1;θ)θTf(x2;θ)θTf(xn;θ)θT]\boxed{ J(\theta) = - \begin{bmatrix} \frac{\partial f(\mathbf{x}_1; \theta)}{\partial \theta^T} \\ \frac{\partial f(\mathbf{x}_2; \theta)}{\partial \theta^T} \\ \vdots \\ \frac{\partial f(\mathbf{x}_n; \theta)}{\partial \theta^T} \end{bmatrix} }

这里nn表示数据量的个数,pp表示待定参数的个数;mm则有点绕,表示每个数据样本的输出维度,即问题模型输出多少个值。其实这里考虑mm确实会增加问题的复杂度,直接将其设置为1来理解就可以了。或者使用分块形式来简化表达,令

Ji(θ)=f(xi;θ)θTRm×pJ_i(\theta) = \frac{\partial f(\mathbf{x}_i; \theta)}{\partial \theta^T} \in \mathbb{R}^{m \times p}

是第 ii 个样本的模型输出对参数的雅可比块

则整体雅可比为:

J(θ)=[J1(θ)TJ2(θ)TJn(θ)T]TJ(\theta) = - \begin{bmatrix} J_1(\theta)^T & J_2(\theta)^T & \cdots & J_n(\theta)^T \end{bmatrix}^T

4. Gauss-Newton

求解非线性最小二乘问题最基础最好理解的就是Gauss-Newton方法,它结合了牛顿法的迭代优化框架(就是高中数学中迭代逼近求解平方根的过程)和高斯的线性化思想,所以将其称为Gauss-Newton方法。它的算法流程如下:

  1. 初始化:选一个初始猜测 θ0\theta_0

  2. 迭代:对 k=0,1,2,k = 0, 1, 2, \dots a. 计算当前残差:rk=yf(x;θk)\mathbf{r}_k = \mathbf{y} - f(\mathbf{x}; \theta_k) b. 计算雅可比矩阵 Jk=J(θk)J_k = J(\theta_k) c. 求解线性最小二乘子问题

    minΔθJkΔθ+rk2\min_{\Delta \theta} \| J_k \Delta \theta + \mathbf{r}_k \|^2

    解为:

    Δθ=(JkTJk)1JkTrk\Delta \theta = - (J_k^T J_k)^{-1} J_k^T \mathbf{r}_k

    d. 更新参数:

    θk+1=θk+Δθ\theta_{k+1} = \theta_k + \Delta \theta
  3. 终止:当 Δθ\|\Delta \theta\| 很小或目标函数变化很小时停止

Gauss-Newton方法的基本思路是每一步都在当前点附近做线性近似;然后走一步,走的方向是让残差平方和下降最快的方向之一;最终收敛到一个局部最小值。可能这个算法流程可能还是有点抽象,我们将其中一次迭代的过程论述的更清楚一些:

  1. θk\theta_k 处做一阶泰勒展开。对残差函数 r(θ)\mathbf{r}(\theta)θk\theta_k 附近线性化:

    r(θ)r(θk)+J(θk)(θθk)\mathbf{r}(\theta) \approx \mathbf{r}(\theta_k) + J(\theta_k) (\theta - \theta_k)

    Δθ=θθk\Delta \theta = \theta - \theta_k,则:

    r(θ)rk+JkΔθ\mathbf{r}(\theta) \approx \mathbf{r}_k + J_k \Delta \theta

    其中:

    • rk=r(θk)\mathbf{r}_k = \mathbf{r}(\theta_k)
    • Jk=J(θk)J_k = J(\theta_k)
  2. 构造局部二次近似目标函数。代入原目标:

    S(θ)=r(θ)2rk+JkΔθ2S(\theta) = \| \mathbf{r}(\theta) \|^2 \approx \| \mathbf{r}_k + J_k \Delta \theta \|^2

    展开:

    S(θ)rkTrk+2rkTJkΔθ+ΔθTJkTJkΔθS(\theta) \approx \mathbf{r}_k^T \mathbf{r}_k + 2 \mathbf{r}_k^T J_k \Delta \theta + \Delta \theta^T J_k^T J_k \Delta \theta

    这是一个关于 Δθ\Delta \theta二次函数

  3. 最小化这个二次函数。对 Δθ\Delta \theta 求导并令导数为零:

    S(Δθ)=2JkTrk+2JkTJkΔθ=0\frac{\partial S}{\partial (\Delta \theta)} = 2 J_k^T \mathbf{r}_k + 2 J_k^T J_k \Delta \theta = 0

    得到正规方程(Normal Equation):

    JkTJkΔθ=JkTrk\boxed{ J_k^T J_k \Delta \theta = - J_k^T \mathbf{r}_k }
  4. 求解 Gauss-Newton 步长。如果 JkTJkJ_k^T J_k 可逆,则解为:

    Δθ=(JkTJk)1JkTrk\boxed{ \Delta \theta = - (J_k^T J_k)^{-1} J_k^T \mathbf{r}_k }
  5. 更新参数

    θk+1=θk+Δθ\theta_{k+1} = \theta_k + \Delta \theta

看到这个过程中的正规方程了吗?这就是我们说的非线性最小二乘求解的基础是线性最小二乘的原因了,非线性最小二乘问题的每次迭代过程就是一个线性最小二乘子问题。

非线性最小二乘与线性最小二乘求解过程的对比如下:

特性线性最小二乘非线性最小二乘(Gauss-Newton)
模型f(x;θ)=Aθf(x; \theta) = A \thetaf(x;θ)f(x; \theta) 任意非线性
残差r=Aθb\mathbf{r} = A\theta - br(θ)=yf(x;θ)\mathbf{r}(\theta) = \mathbf{y} - f(\mathbf{x}; \theta)
雅可比J=AJ = A(常数)J(θ)=fθTJ(\theta) = -\frac{\partial f}{\partial \theta^T}(依赖 θ\theta
θ=(ATA)1ATb\theta^* = (A^T A)^{-1} A^T bθk+1=θk(JkTJk)1JkTrk\theta_{k+1} = \theta_k - (J_k^T J_k)^{-1} J_k^T \mathbf{r}_k
是否迭代