根据经典的SLAM模型,它有一个运动方程一个观测方程。
{ x k = f ( x k − 1 , u k ) + w k z k , j = h ( y j , x k ) + v k , j \left\{\begin{array}{l} x_{k}=f\left(x_{k-1}, \boldsymbol{u}_{k}\right)+\boldsymbol{w}_{k} \\ \boldsymbol{z}_{k, j}=h\left(\boldsymbol{y}_{j}, \boldsymbol{x}_{k}\right)+\boldsymbol{v}_{k, j} \end{array}\right. {xk=f(xk−1,uk)+wkzk,j=h(yj,xk)+vk,j
运动方程可以理解为:在 x k x_{k} xk点处,通过传感器得到的数据 u k u_k uk和上一时刻的位置 x k − 1 x_{k-1} xk−1进而计算出当前时刻的位置 x k x_k xk。
观测方程可以理解为:在 x k x_k xk处观测 y i y_i yi点时的路标时得到的数据 z k , j z_{k,j} zk,j。具体这样的形式是从针孔模型得到的。
假设在 x k x_k xk处对路标 y j \boldsymbol{y}_j yj进行了一次观测,对应到图像上的像素位置 z k , j z_{k,j} zk,j,那么,观测方程可以表示成
s z k , j = K ( R k y j + t k ) s z_{k, j}=\boldsymbol{K}\left(\boldsymbol{R}_{k} \boldsymbol{y}_{j}+\boldsymbol{t}_{k}\right) szk,j=K(Rkyj+tk)
其中 K \boldsymbol{K} K为相机参数, s s s为像素点的距离,也是 ( R k y j + t k ) \left(\boldsymbol{R}_{k} \boldsymbol{y}_{j}+\boldsymbol{t}_{k}\right) (Rkyj+tk)的第三个分量。
在运动和观测方程中,我们通常假设两个噪声项 w k , v k , j \boldsymbol{w}_{k},\boldsymbol{v}_{k, j} wk,vk,j满足零均值的高斯分布。
w k ∼ N ( 0 , R k ) , v k ∼ N ( 0 , Q k , j ) w_{k} \sim \mathcal{N}\left(\mathbf{0}, \boldsymbol{R}_{k}\right), \boldsymbol{v}_{k} \sim \mathcal{N}\left(\mathbf{0}, \boldsymbol{Q}_{k, j}\right) wk∼N(0,Rk),vk∼N(0,Qk,j)
在这里, N \mathcal{N} N表示高斯分布,0表示零均值, R k , Q k , j \boldsymbol{R}_{k},\boldsymbol{Q}_{k, j} Rk,Qk,j表示协方差矩阵。在这样带有噪声的情况下,希望数据 z \boldsymbol{z} z和 u \boldsymbol{u} u推断出位姿 x \boldsymbol{x} x和地图 y \boldsymbol{y} y,这就构成了状态估计的问题。
状态估计的解决方法分为两种:
缺点:
折衷方法:仅对当前时刻附近的一些轨迹进行优化。
从概率学的观点来看,就是已知输入数据 u \boldsymbol{u} u和观测数据 z \boldsymbol{z} z的条件下,求状态 x , y \boldsymbol{x,y} x,y的条件概率分布:
P ( x , y ∣ z , u ) P(\boldsymbol{x}, \boldsymbol{y} \mid \boldsymbol{z}, \boldsymbol{u}) P(x,y∣z,u)
当我们不知道控制输入时,只有一张张地图像时,即只考虑观测方程带来的数据时,相当于估计 P ( x , y ∣ z ) P(\boldsymbol{x}, \boldsymbol{y} \mid \boldsymbol{z}) P(x,y∣z)的条件概率分布,该问题就是SfM,即如何从许多图像中重建三维空间结构。
在对上式运用贝叶斯法则:
P ( x , y ∣ z , u ) = P ( z , u ∣ x , y ) P ( x , y ) P ( z , u ) ∝ P ( z , u ∣ x , y ) ⏟ 似然 P ( x , y ) ⏟ 先验 . P(x, y \mid z, u)=\frac{P(z, u \mid x, y) P(x, y)}{P(z, u)} \propto \underbrace{P(z, u \mid x, y)}_{\text {似然}} \underbrace{P(x, y)}_{\text {先验}} . P(x,y∣z,u)=P(z,u)P(z,u∣x,y)P(x,y)∝似然 P(z,u∣x,y)先验 P(x,y).
左侧部分为后验概率,似然和先验已经在图中标注出来了。
直接求后验分布式困难的,但是求一个状态最优估计,使得在该状态下后验概率最大化是方便的
( x , y ) ∗ Map = arg max P ( x , y ∣ z , u ) = arg max P ( z , u ∣ x , y ) P ( x , y ) (x, y)^{*} \text { Map }=\arg \max P(x, y \mid z, u)=\arg \max P(z, u \mid x, y) P(x, y) (x,y)∗ Map =argmaxP(x,y∣z,u)=argmaxP(z,u∣x,y)P(x,y)
分母部分由于与带估计的状态 x , y x,y x,y无关,因此可以忽略。因此求最大后验概率就是求最大似然和先验的乘积。如果没有先验,那么就可以求最大似然估计(MLE)
( x , y ) ∗ M L E = arg max P ( z , u ∣ x , y ) (\boldsymbol{x}, \boldsymbol{y})^{*} \mathrm{MLE}=\arg \max P(\boldsymbol{z}, \boldsymbol{u} \mid \boldsymbol{x}, \boldsymbol{y}) (x,y)∗MLE=argmaxP(z,u∣x,y)
思想:从传感器或者图片观测数据中获取位置和路标信息并不容易时,就反过来思考,什么样的位置和路标信息能够得到这样的观测数据
要求最大似然估计,这时,最大似然估计的简单表达式在干扰为正态分布(又名“高斯分布”)时最简单。
对观测模型,某一次观测:
z k , j = h ( y j , x k ) + v k , j z_{k, j}=h\left(y_{j}, x_{k}\right)+v_{k, j} zk,j=h(yj,xk)+vk,j
噪声项 v k ∼ N ( 0 , Q k , j ) \boldsymbol{v}_{k} \sim \mathcal{N}\left(\mathbf{0}, \boldsymbol{Q}_{k, j}\right) vk∼N(0,Qk,j),所以观测数据的条件概率为:
P ( z j , k ∣ x k , y j ) = N ( h ( y j , x k ) , Q k , j ) P\left(z_{j, k} \mid x_{k}, y_{j}\right)=\mathcal{N}\left(h\left(y_{j}, x_{k}\right), \boldsymbol{Q}_{k, j}\right) P(zj,k∣xk,yj)=N(h(yj,xk),Qk,j)
仍旧是正态分布,考虑单次观测的最大似然估计,可以使用最小化负对数来求一个正态分布的最大似然。
对于任意高维正态分布 x ∼ N ( μ , Σ ) \boldsymbol{x} \sim \mathcal{N}(\mu, \boldsymbol{\Sigma}) x∼N(μ,Σ),其概率密度函数展开形式为:
P ( x ) = 1 ( 2 π ) N det ( Σ ) exp ( − 1 2 ( x − μ ) T Σ − 1 ( x − μ ) ) P(x)=\frac{1}{\sqrt{(2 \pi)^{N} \operatorname{det}(\Sigma)}} \exp \left(-\frac{1}{2}(x-\mu)^{\mathrm{T}} \mathbf{\Sigma}^{-1}(x-\mu)\right) P(x)=(2π)Ndet(Σ)1exp(−21(x−μ)TΣ−1(x−μ))
取负对数:
− ln ( P ( x ) ) = 1 2 ln ( ( 2 π ) N det ( Σ ) ) + 1 2 ( x − μ ) T Σ − 1 ( x − μ ) -\ln (P(x))=\frac{1}{2} \ln \left((2 \pi)^{N} \operatorname{det}(\Sigma)\right)+\frac{1}{2}(x-\mu)^{\mathrm{T}} \Sigma^{-1}(x-\mu) −ln(P(x))=21ln((2π)Ndet(Σ))+21(x−μ)TΣ−1(x−μ)
因为对数函数是单调递增的,所以对原函数求最大化相当于对负对数求最小化。在最小化上式的 x x x时,第一项与 x x x无关,可以略去。于是,只要最小化右侧的二次型项,就得到了对状态的最大似然估计。对于SLAM相当于在求:
( x k , y j ) ∗ = arg max N ( h ( y j , x k ) , Q k , j ) = arg min ( ( z k , j − h ( x k , y j ) ) ⊤ Q k , j − 1 ( z k , j − h ( x k , y j ) ) ) \begin{aligned} \left(x_{k}, y_{j}\right)^{*} &=\arg \max \mathcal{N}\left(h\left(y_{j}, x_{k}\right), Q_{k, j}\right) \\ &=\arg \min \left(\left(z_{k, j}-h\left(x_{k}, y_{j}\right)\right)^{\top} Q_{k, j}^{-1}\left(z_{k, j}-h\left(x_{k}, y_{j}\right)\right)\right) \end{aligned} (xk,yj)∗=argmaxN(h(yj,xk),Qk,j)=argmin((zk,j−h(xk,yj))⊤Qk,j−1(zk,j−h(xk,yj)))
该式等价于最小化噪声项(即误差)的一个二次型。这个二次型称为马哈拉诺比斯距离,又叫马氏距离它也可以看成由 Q k , j − 1 Q_{k, j}^{-1} Qk,j−1加权之后的欧氏距离(二范数),这里 Q k , j − 1 Q_{k, j}^{-1} Qk,j−1也叫作信息矩阵,即高斯分布协方差矩阵之逆。
假设各个时刻的输入和观测是相互独立的,这意味着各个输入之间是独立的,各个观测之间是独立的,并且输入和观测是相互独立的。因此:
P ( z , u ∣ x , y ) = ∏ k P ( u k ∣ x k − 1 , x k ) ∏ k , j P ( z k , j ∣ x k , y j ) P(z, u \mid x, y)=\prod_{k} P\left(u_{k} \mid x_{k-1}, x_{k}\right) \prod_{k, j} P\left(z_{k, j} \mid x_{k,} y_{j}\right) P(z,u∣x,y)=k∏P(uk∣xk−1,xk)k,j∏P(zk,j∣xk,yj)
这说明我们可以独立地处理各时刻地运动和观测。定义各次输入和观测数据与模型之间地误差:
e u , k = x k − f ( x k − 1 , u k ) e z , j , k = z k , j − h ( x k , y j ) \begin{gathered} e_{u, k}=x_{k}-f\left(x_{k-1}, u_{k}\right) \\ e_{z, j, k}=z_{k, j}-h\left(x_{k}, y_{j}\right) \end{gathered} eu,k=xk−f(xk−1,uk)ez,j,k=zk,j−h(xk,yj)
那么,最小化所有时刻估计值与真实读数之间地马氏距离,等价于求最大似然估计。负对数允许把乘积变成求和:
min J ( x , y ) = ∑ k e u , k T R k − 1 e u , k + ∑ k ∑ j e z , k , j T Q k , j − 1 e z , k , j \min J(x, y)=\sum_{k} e_{u, k}^{T} R_{k}^{-1} e_{u, k}+\sum_{k} \sum_{j} e_{z, k, j}^{T} Q_{k, j}^{-1} e_{z, k, j} minJ(x,y)=k∑eu,kTRk−1eu,k+k∑j∑ez,k,jTQk,j−1ez,k,j
这样就得到了一个最小二乘问题,它的解等价于状态的最大似然估计。
SLAM中的最小二乘问题具有的一些特定的结构:
1.整个问题的目标函数由许多个误差(加权的)二次型组成。虽然总体的状态变量维数很高,但每个误差项都是简单的,仅与一两个状态变量有关。
2.如果使用李代数表示增量,则该问题是无约束的最小二乘问题。但如果用旋转矩阵/变换矩阵描述位姿,则会引入旋转矩阵自身的约束。额外的约束会使优化变得更困难。这体现了李代数的优势。
3.我们使用了二次型度量误差。误差的分布将影响此项在整个问题中的权重。如果某次观测的非常准确,那么协方差矩阵就会“小”,而信息矩阵就会“大”,所以这个误差项会在整个问题中占有较高的权重。
我们对状态的估计值进行微调,使得整体的误差下降一些,一般会下降达到一个极小值。这就是一个典型的非线性优化的过程。
接下来使用最小二乘的解法来解决上述问题。
可以看这个链接的最小二乘最小二乘问题总结也可以看接下来的SLAM书上的解决方法
一个简单的最小二乘问题:
min x F ( x ) = 1 2 ∥ f ( x ) ∥ 2 2 \min _{x} F(x)=\frac{1}{2}\|f(\boldsymbol{x})\|_{2}^{2} xminF(x)=21∥f(x)∥22
其中,自变量 x ∈ R n \boldsymbol{x} \in \mathbb{R}^{n} x∈Rn, f f f是任意的标量非线性函数 f ( x ) f(x) f(x)。这里的 1 / 2 1/2 1/2是无关紧要的,不影响结论。求最优值就求导,并令导数为0
d F d x = 0 \frac{\mathrm{d} F}{\mathrm{~d} \boldsymbol{x}}=\mathbf{0} dxdF=0
即得到的值,可能是极大、极小或鞍点处的值,只要比较大小即可。如果 f ( x ) f(x) f(x)是简单的线性函数,那么就是线性最小二乘问题。
有些函数形式复杂,不容易求导或者导数后不容易求解,而且又可能需要知道目标函数的全局性质,因此求导并求解这一步比较难,因此可以使用迭代的方式:从一个初始值出发不断地更新当前地优化变量,使目标函数下降。具体步骤为:
1.给定某个初始值 x 0 x_0 x0
2.对于第 k k k次迭代,寻找一个增量 Δ x k \Delta x_{k} Δxk,使得 ∥ f ( x k + Δ x k ) ∥ 2 2 \left\|f\left(\boldsymbol{x}_{k}+\Delta \boldsymbol{x}_{k}\right)\right\|_{2}^{2} ∥f(xk+Δxk)∥22达到极小值。
3.若 Δ x k \Delta x_{k} Δxk足够小,则停止
4.否则,令 x k + 1 = x k + Δ x k \boldsymbol{x}_{k+1}=\boldsymbol{x}_{k}+\Delta \boldsymbol{x}_{k} xk+1=xk+Δxk,返回第2步。
这让求解导数为0的问题变成了一个不断**寻找下降增量 Δ x k \Delta x_{k} Δxk**的问题。在找 Δ x k \Delta x_{k} Δxk的过程中,只需了解 f f f在迭代值处的局部性质而非全局性质。当函数下降直到增量非常小的时候,就认为算法收敛,目标函数达到了一个极小值。
考虑第 k k k次迭代,假设在 x k x_k xk处,想要寻找到增量 Δ x k \Delta x_{k} Δxk,最直观的方式是讲目标函数在 x k x_k xk附近进行泰勒展开:
F ( x k + Δ x k ) ≈ F ( x k ) + J ( x k ) T Δ x k + 1 2 Δ x k T H ( x k ) Δ x k F\left(x_{k}+\Delta x_{k}\right) \approx F\left(x_{k}\right)+J\left(x_{k}\right)^{\mathrm{T}} \Delta x_{k}+\frac{1}{2} \Delta x_{k}^{\mathrm{T}} H\left(x_{k}\right) \Delta x_{k} F(xk+Δxk)≈F(xk)+J(xk)TΔxk+21ΔxkTH(xk)Δxk
其中 J ( x k ) J\left(x_{k}\right) J(xk)是 F ( x ) F(x) F(x)关于 x x x的一阶导数(也叫梯度、雅可比(Jacobian)矩阵), H H H则是二阶导数(海塞(Hessian)矩阵),他们都在 x k x_k xk处取值。
保留泰勒展开的一阶或者二阶项,对应的求解方法称为一阶梯度或二阶梯度法。如果保留一阶梯度,那么取增量为反向的梯度,即可保证函数下降:
Δ x ∗ = − J ( x k ) \Delta \boldsymbol{x}^{*}=-\boldsymbol{J}\left(\boldsymbol{x}_{k}\right) Δx∗=−J(xk)
这种方法被称为最速下降法。直观意义就是只要我们沿着反向梯度方向前进,在一阶(线性)的近似下,目标函数必定会下降。
保留二阶梯度信息,增量方程为:
Δ x ∗ = arg min ( F ( x ) + J ( x ) T Δ x + 1 2 Δ x T H Δ x ) \Delta x^{*}=\arg \min \left(F(x)+J(x)^{\mathrm{T}} \Delta x+\frac{1}{2} \Delta x^{\mathrm{T}} H \Delta x\right) Δx∗=argmin(F(x)+J(x)TΔx+21ΔxTHΔx)
右侧只含了 Δ x \Delta x Δx的零次、一次和二次项。求右侧等式关于 Δ x \Delta x Δx的导数并令它为零,得到:
J + H Δ x = 0 ⇒ H Δ x = − J J+H \Delta x=0 \Rightarrow H \Delta x=-J J+HΔx=0⇒HΔx=−J
求解这个线性方程就得到了增量,这个方法为牛顿法
一阶和二阶梯度法从字面意思可以理解,就是对误差函数进行泰勒展开保留一阶或者二阶,然后求 Δ x \Delta x Δx使得整个函数值向小的方向进展,保留一阶就是最速下降法、保留二阶就是牛顿法,方法就是把函数在迭代点附近及逆行泰勒展开,并针对更新量做最小化即可
缺点:最速下降法过于贪心。容易走出锯齿路线,反而增加了迭代次数,牛顿法则需要计算木匾函数的 H H H矩阵,规模较大时不方便计算
针对上面的缺点,提出的拟牛顿法:高斯牛顿法和列文伯格–马夸尔特方法
高斯牛顿法的思想:对 f ( x ) f(x) f(x)进行一阶的泰勒展开,与牛顿法的最大区别就是:牛顿法是对 F ( x ) F(x) F(x)进行的一阶泰勒展开,它俩的关系是 min x F ( x ) = 1 2 ∥ f ( x ) ∥ 2 2 \min _{x} F(x)=\frac{1}{2}\|f(\boldsymbol{x})\|_{2}^{2} minxF(x)=21∥f(x)∥22
(这里可以把 f ( x ) f(x) f(x)理解为误差 e ( x ) e(x) e(x),而 F ( x ) F(x) F(x)理解为包含误差的函数)
f ( x + Δ x ) ≈ f ( x ) + J ( x ) Δ x f(\boldsymbol{x}+\Delta \boldsymbol{x}) \approx f(\boldsymbol{x})+\boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x} f(x+Δx)≈f(x)+J(x)Δx
寻求 Δ x \Delta x Δx使得 ∥ f ( x + Δ x ) ∥ 2 \|f(x+\Delta x)\| ^2 ∥f(x+Δx)∥2达到最小(为什么是求它达到最小:1.因为 f ( x ) f(x) f(x)与 F ( x ) F(x) F(x)的关系。2.是因为后边的展开后的式子包含了 Δ x \Delta x Δx的平方项,这就跟牛顿相比减少了求 H H H的效果,进而说明了为什么前面展开一阶就可以了),进而转换成求解一个线性的最小二乘问题:
Δ x ∗ = arg min Δ x 1 2 ∥ f ( x ) + J ( x ) Δ x ∥ 2 \Delta \boldsymbol{x}^{*}=\arg \min _{\Delta \boldsymbol{x}} \frac{1}{2}\|f(\boldsymbol{x})+\boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}\|^{2} Δx∗=argΔxmin21∥f(x)+J(x)Δx∥2
展开后的式子为:
1 2 ∥ f ( x ) + J ( x ) Δ x ∥ 2 = 1 2 ( f ( x ) + J ( x ) Δ x ) T ( f ( x ) + J ( x ) Δ x ) = 1 2 ( ∥ f ( x ) ∥ 2 2 + 2 f ( x ) T J ( x ) Δ x + Δ x T J ( x ) T J ( x ) Δ x ) . \begin{aligned} \frac{1}{2}\|f(\boldsymbol{x})+\boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}\|^{2} &=\frac{1}{2}(f(\boldsymbol{x})+\boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x})^{\mathrm{T}}(f(\boldsymbol{x})+\boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}) \\ &=\frac{1}{2}\left(\|f(\boldsymbol{x})\|_{2}^{2}+2 f(\boldsymbol{x})^{\mathrm{T}} \boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}+\Delta \boldsymbol{x}^{\mathrm{T}} \boldsymbol{J}(\boldsymbol{x})^{\mathrm{T}} \boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}\right) . \end{aligned} 21∥f(x)+J(x)Δx∥2=21(f(x)+J(x)Δx)T(f(x)+J(x)Δx)=21(∥f(x)∥22+2f(x)TJ(x)Δx+ΔxTJ(x)TJ(x)Δx).
对 Δ x \Delta x Δx求导,并令其为0:
2 J ( x ) T f ( x ) + 2 J ( x ) T J ( x ) Δ x = 0 2 \boldsymbol{J}(\boldsymbol{x})^{\mathrm{T}} f(\boldsymbol{x})+2 \boldsymbol{J}(\boldsymbol{x})^{\mathrm{T}} \boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}=\mathbf{0} 2J(x)Tf(x)+2J(x)TJ(x)Δx=0
得到:
J ( x ) J T ⏟ H ( x ) ( x ) Δ x = − J ( x ) f ( x ) ⏟ g ( x ) \underbrace{\boldsymbol{J}(\boldsymbol{x}) \boldsymbol{J}^{\mathrm{T}}}_{\boldsymbol{H}(\boldsymbol{x})}(\boldsymbol{x}) \Delta \boldsymbol{x}=\underbrace{-\boldsymbol{J}(\boldsymbol{x}) f(x)}_{\boldsymbol{g}(\boldsymbol{x})} H(x) J(x)JT(x)Δx=g(x) −J(x)f(x)
这个方程为增量方程,是 Δ x \Delta x Δx的线性方程,也叫高斯牛顿方程或者正规方程。那么上式就为:
H Δ x = g . \boldsymbol{H} \Delta \boldsymbol{x}=\boldsymbol{g} . HΔx=g.
拿这个与牛顿法进行对比: H Δ x = − J H \Delta x=-J HΔx=−J可以看出:高斯牛顿法是用 J J T JJ^T JJT作为牛顿法中的 H H H,进而省略了 H H H的计算。
整个步骤可以总结为:
1.给定初始值 x 0 x_0 x0
2.对于第k次迭代,求出当前的雅可比矩阵 J ( x k ) J(x_k) J(xk)和误差 f ( x k ) f(x_k) f(xk)。
3.求解增量方程: H ∆ x k = g H∆x_k =g H∆xk=g。
4.若 ∆ x k ∆x_k ∆xk足够小,则停止。否则,令 x k + 1 = x k + ∆ x k x_{k+1}=x_k+∆x_k xk+1=xk+∆xk,返回第2步。
增量方程的求解占据着主要地位,只要能顺利求出增量,就能保证目标函数正确下降。
**缺点:**它要求 H H H是可逆的(而且是正定的),但实际数据中计算得到的 J J T JJ^T JJT却只有半正定性。也就是说,在使用高斯牛顿法时,可能出现 J J T JJ^T JJT为奇异矩阵或者病态的情况,此时增量的稳定性较差,导致算法不收敛。更严重的是,就算我们假设非奇异也非病态,如果我们求出来的步长 Δ x \Delta x Δx太大,也会导致我们采用的局部近似不够准确,这样一来我们甚至无法保证它的迭代收敛,哪怕是让目标函数变得更大都是有可能的。
这个方法的思想是:一阶梯度下降法也就是最速下降法与高斯牛顿法相结合,定义了一个信赖区域来决定谁来起主导作用。
信赖区域:给 Δ x \Delta x Δx添加一个范围,定义了在什么情况下二阶近似(是对 F ( x ) F(x) F(x)说的二阶,对 f ( x ) f(x) f(x)说的一阶)是有效的。出了区域近似可能会出问题。
定义了一个指标 ρ \rho ρ来计算二阶及其更高阶对近似的作用大小:
ρ = f ( x + Δ x ) − f ( x ) J ( x ) Δ x \rho=\frac{f(\boldsymbol{x}+\Delta \boldsymbol{x})-f(\boldsymbol{x})}{\boldsymbol{J}(\boldsymbol{x}) \Delta \boldsymbol{x}} ρ=J(x)Δxf(x+Δx)−f(x)
分子:实际函数下降的值,分母:近似模型下降的值
如果 ρ \rho ρ接近于1,则近似是好的。如果 ρ \rho ρ太小,说明实际减小的值远少于近似减小的值,则认为近似比较差,需要缩小近似范围。反之,如果 ρ \rho ρ比较大,则说明实际下降的比预计的更大,我们可以放大近似范围。
改良版的非线性优化框架,比高斯牛顿法会有更好的效果:
- 给定初始值 x 0 x_0 x0,以及初始优化半径 μ \mu μ
- 对于第k次迭代,在高斯牛顿法的基础上机上信赖区域,求解:
min Δ x k 1 2 ∥ f ( x k ) + J ( x k ) Δ x k ∥ 2 , s.t. ∥ D Δ x k ∥ 2 ⩽ μ \min _{\Delta \boldsymbol{x}_{k}} \frac{1}{2}\left\|f\left(\boldsymbol{x}_{k}\right)+\boldsymbol{J}\left(\boldsymbol{x}_{k}\right) \Delta \boldsymbol{x}_{k}\right\|^{2}, \quad \text { s.t. }\left\|\boldsymbol{D} \Delta \boldsymbol{x}_{k}\right\|^{2} \leqslant \mu Δxkmin21∥f(xk)+J(xk)Δxk∥2, s.t. ∥DΔxk∥2⩽μ
其中, μ \mu μ是信赖区域的半径, D D D为系数矩阵,如果 D D D为 I I I,则表示把 Δ x \Delta x Δx约束在一个球中。- 按上式计算 ρ \rho ρ
- 若 ρ > 3 4 \rho>\frac{3}{4} ρ>43,则设置 μ = 2 μ \mu = 2\mu μ=2μ
- 若 ρ < 1 4 \rho<\frac{1}{4} ρ<41,则设置 μ = 0.5 μ \mu = 0.5\mu μ=0.5μ
- 如果 ρ \rho ρ大于某阈值,则认为近似可行。令 x k + 1 = x k + Δ x x_{k+1}=x_k+\Delta x xk+1=xk+Δx
- 判断算法是否收敛。如果不收敛返回第2步,否则结束。
用拉格朗日乘子把约束项放到目标函数中,构成拉个朗日函数:
min Δ x k 1 2 ∥ f ( x k ) + J ( x k ) T Δ x k ∥ 2 + λ 2 ∥ D Δ x − μ ∥ 2 . \min _{\Delta \boldsymbol{x}_{k}} \frac{1}{2}\left\|f\left(\boldsymbol{x}_{k}\right)+\boldsymbol{J}\left(\boldsymbol{x}_{k}\right)^T \Delta \boldsymbol{x}_{k}\right\|^{2}+\frac{\lambda}{2}\|\boldsymbol{D} \Delta \boldsymbol{x}-\mu\|^{2} . Δxkmin21∥∥∥f(xk)+J(xk)TΔxk∥∥∥2+2λ∥DΔx−μ∥2.
这里 λ \lambda λ为拉格朗日算子。求导,计算增量:
( H + λ D T D ) Δ x = g \left(\boldsymbol{H}+\lambda \boldsymbol{D}^{\mathrm{T}} \boldsymbol{D}\right) \Delta \boldsymbol{x}=\boldsymbol{g} (H+λDTD)Δx=g
( H + λ I ) Δ x = g \left(\boldsymbol{H}+\lambda \boldsymbol{I}\right) \Delta \boldsymbol{x}=\boldsymbol{g} (H+λI)Δx=g
我们看到,当参数 λ \lambda λ比较小时, H H H占主要地位,这说明二次近似模型在该范围内是比较好的,列文伯格—马夸尔特方法更接近于高斯牛顿法。另一方面,当 λ \lambda λ比较大时, λ I \lambda I λI占据主要地位,列文伯格—马夸尔特方法更接近于一阶梯度下降法(即最速下降),这说明附近的二次近似不够好。列文伯格—马夸尔特方法的求解方式,可在一定程度上避免线性方程组的系数矩阵的非奇异和病态问题,提供更稳定、更准确的增量 Δ x \Delta x Δx
1.视觉SLAM十四讲