对于最优化问题,如果目标函数是非线性的,那就是非线性优化问题,如果目标函数是凸函数,那就是凸优化问题。
首先需要说明的是,最初的问题其实是一个最优化问题。所谓的最优化问题其实就是寻找最优解的问题,一般形式是寻找函数的最大值或者最小值(一般都是将问题转换成求解目标函数的最小值)。
而非线性优化问题就是针对一个非线性函数求最值的问题。其实,在我们初高中的时候就已经求解过非线性优化的问题了,比如对于如下非线性函数:
求解上面这个非线性函数的最小值,我们可以很轻松的解决,因为这是一个及其简单的非线性优化问题,我们可以直接通过导数为0求解出最小值。但是对于机器学习中的很多非线性目标函数,我们很难像这样直接求解。
首先,什么是非线性最小二乘问题,一般它的形式如下:
此处自变量,f是任意的非线性函数,我们可以假设它有m维:
对于不方便直接求解(令导数为0求得所有候选点然后比较)的最小二乘问题,此时一般使用如下迭代的方法求解最小二乘问题。
上述迭代中很重要的一点是增量如何确定,下面会开始讲解一些代表性的方法。首先将目标函数在x附近进行泰勒展开:
上面J是函数关于x的雅可比(Jacobian)矩阵,而H是其海塞(Hessian)矩阵。
对于输入与输出都是向量的函数,雅可比矩阵是这个函数的一阶偏导数矩阵,海塞矩阵是二阶偏导数矩阵,详细可自行查阅相关资料,此处仅简短说明。
梯度下降法是只考虑一阶导数的优化方法,优化思想是使用当前位置负梯度方向作为搜索方向,因为该方向为当前位置的最快下降方向,所以也叫做最速下降法。(没什么计算,单纯想法是向负梯度方向前进)
缺点:
由于梯度下降法在接近最优解的区域收敛速度明显变慢,因此会需要很多次的迭代,因此出现了一些改进的方法
牛顿法同时考虑一阶与二阶梯度信息,增量方程为
上式中右侧等式关于求导并另它为零,就得到了增量的解。
牛顿法很好,但是需要计算目标函数的海塞矩阵,这在问题规模较大时十分困难。因此出现了下面两种实用的改进方法
此处的是函数关于x的雅可比矩阵。因为目标是寻找一个下降矢量使得达到最小。为了求,我们会求解如下的最小二乘问题
上面这个等式是一个关于的线性方程组,我们称它为增量方程,也叫高斯牛顿方程或者正规方程。我们可以将左侧系数定义为H,右侧系数定义为g,上式变为
与牛顿法对比,高斯牛顿法用作为牛顿法中海塞矩阵的近似,从而省略了H的计算。整个优化问题的核心变成求解增量方程。
缺点:
对了,高斯牛顿法只能处理二次函数,使用时必须将目标函数转化为二次的。
由于高斯牛顿法中采用的近似二阶泰勒展开只能在展开点附近有较好的近似效果,所以我们很自然的想到给Δ添加一个信赖区域,使得其不会过大。
确定信赖区域的方法:根据我们的近似模型和实际函数之间的差异来确定信赖区域,如果差异小,我们就让范围尽可能大;如果差异大,我们就缩小这个近似范围。使用如下参数
来判断泰勒近似是否够好,分子是实际函数下降的值,分母是近似模型下降的值。
上面近似范围扩大的倍数与阈值都是经验值,可以替换成别的数值。在第二步的求解中,我们将增量限定在一个半径为的球里,带上D之后,这个球可以看成一个椭球。通常D为单位矩阵时,是一个正球体。
现在我们来确定LM方法中的,首先使用拉格朗日乘子法将上述带不等式约束的优化问题转换成一个无约束的优化问题
此处的为拉格朗日乘子。上述做法类似于高斯牛顿法中的做法,对上述问题求解,我们得到下式:
由上我们发现该问题的核心仍然是计算增量的线性方程,相比较高斯牛顿法的方程,LM中多了一项。考虑上式的简化版本,我们另,这个方程变为:
我们发现,当比较小时,LM方法近似与高斯牛顿法;当比较大时,说明附近的二次近似不太好,LM方法近似于最速下降法。
列文伯格-马夸尔特方法可在一定程度上米面线性方程组的系数矩阵的非奇异和病态问题,提供更稳定、准确的增量。尽管它的收敛速度可能会比高斯牛顿法更慢,也被叫做阻尼牛顿法。
忽略上面对LM算法来源的说明,其实LM算法主要核心方程是:
上面这个式子的求解结果为(其中即为):
其中,是 的第j个特征值,是其对应的特征向量。(这个式子可以自行推导)
上面阻尼因子作用如下:
大于0保证了正定,迭代朝着下降方向进行。
非常大,说明此时高斯牛顿的一次泰勒展开近似效果不好,更新方式偏向近似最速下降法。
比较小,说明此时高斯牛顿的一次泰勒展开近似效果挺好的,更新方式偏向近似高斯牛顿法。
这种方法的核心问题其实是阻尼因子的更新策略,更新一般是根据上面提到的来进行的。首先,
其次有
而为(分母为更新前后目标函数的变化,分子为近似中应该变化的大小):
在上面已经提到了一种阻尼因子更新的策略(1963年由Marquardt提出):
但是这个策略不是很好,会出现阻尼因子来回波动的情况,目前在ceres与g2o等优化库中一般采用Nielsen策略:
在设置阻尼因子的初始值时,一般采取的策略是(最大的那个特征值乘以一个常数):
其中可以按需设置
这种方法与LM方法思想类似,它是高斯牛顿与梯度下降法的混合。
它的做法是,在信任区域内部,使用高斯牛顿法;否则,使用最速下降法。如果最速下降方向在有效范围内部,使用高斯牛顿与梯度下降的混合,在外部,缩小到Region的边界。
由于最小二乘法会将残差进行平方,因此如果出现outlier,此时它的误差也会进行平方,如果这个误差很大,会很影响优化的进行,所以通常会在残差上加上一个鲁棒核函数来最小化outlier的影响。作用形式如下:
上述函数中的的计算稍微复杂一点为:
将上面两式合并,最终可以近似得到下解:
柯西鲁棒核函数定义为:
其中c为控制参数。对s的一阶导和二阶导为:
首先,对目标函数进行非线性优化有一个很大的前提,那就是目标函数连续可导。所以如果目标函数不连续或者不可导,我们就需要想办法使其变得连续可导。比如在slam中处理姿态估计的问题,当姿态使用旋转矩阵与平移变量表示时,显然是不可导的。此时由于欧式矩阵群是一个李群,所以我们会将目标函数映射到其李代数上,此时目标函数就会连续可导了。
初值敏感,并且非线性优化方法求得的只是局部最优解,这个是由梯度下降的原理决定的,由于初始值不确定,使得很容易陷入局部最优中。一般凸优化可以在一定程度上解决这个问题。因为凸函数的局部最优就是全局最优,所以我们可以尝试着将目标函数转换成凸函数,然后再进行优化。
本文中只是大概讲解了一个非线性优化的整体概念,并针对求解非线性最小二乘问题列举了几种优化方法,还有一些其他的优化方法也具有不错的效果,后面会慢慢补充。。。