凸优化问题实例:LASSO
熟悉机器学习算法里面的线性回归或者逻辑回归的同学因该明白LASSO问题,其定义为:
LASSO是Tibshirani(对就是Tibshirani)在1996年JRSSB上的一篇文章上《Regression shrinkage and selection via lasso》提出的。所谓lasso,其全称是least absolute shrinkage and selection operator,其含义是在限制了的情况下,求使得残差平和达到最小的参数的估值。Tibshirani指出,对于回归算法,当足够小的时候,会使得某些回归系数的估值是0,可以起到变量选择的作用,是逐步回归的一种表现。
因此,对于LASSO算法,其是否是凸优化问题?它的解集合是否是唯一的点?
答案是,LASSO问题是凸优化问题,因为和均是凸函数,因此该问题为凸优化问题;如果样本数目大于特征数目,且X满秩,那么,关于二阶微分恒为半正定p.s.d.,因此,解是唯一的;但是,如果样本数目小于特征数目,那么会造成高维特征空间上的维数灾难问题,此时,X为奇异矩阵,则解不唯一。
另一个实例是SVM算法,SVM算法的理论部分我就不多介绍了,会在机器学习算法篇章中对SVM做着重介绍,如果我们记SVM为:
其中,为下图两个虚线边界的距离,为引入分类错误的代价,代表下图错分样本点距正确分类边界的距离。具体如下图:
那么,该问题是否为凸优化问题呢?它的解是否是唯一?
答案是,SVM目标函数是凸优化问题,但是,它的解并不唯一,因为它不是严格凸函数。有兴趣的同学可以留言来解释为什么SVM是凸优化问题!
4. 局部最小值就是全局最小值
局部最优解的定义为:如果,使得,其中y满足,则点x为优化问题的局部最优解(locally optimal)。
对于凸优化问题,凸函数有一个特别的性质,即局部最优解是全剧最优解(local minima are global minima),即如果,同时满足所有约束,那么对于局部,当时,对于所有可行解。相反,非凸优化问题则不具有该性质,如下图所示。
那么我们需要证明的是为什么凸优化问题的局部最优值就是全局最优值?
证明:这里,我们采用反证法来证明该理论,假设x为凸优化问题的局部最优解,意味着函数在范围内的点的值都小于。如果我们假设定理是错误的,那么必然存在一点,使得,且。
此时,假设存在一点,使得,其中,那么:
-
,因为,同时,二者线性组合也必然存在于D;
-
,因为;
-
。
因此,意味着同样也是是凸优化问题的可行解。
然后,因为点在内均成立,所以我们可以假设足够小,但大于0,使得可以落在点以为半径的圆内,这时,对于凸优化问题中可行解的两个点之间的点,我们可以得到如下公式:
又因为,且之前假设,所以,因此,这就与之前最开始假设x为局部最优解的定义相违背,因此,我们最终证明得到local minima are global minima。
5. 凸优化问题的一些性质和Trick
- First-order optimality condition:对于凸优化问题,如果函数可微,那么当且仅当满足下式时,可行解(feasible point)为最优解。
- Partial optimization:如果,那么优化问题
等价于:
其中;
SVM采用的hinge loss就是利用的partial optimization的思想。如果我们把SVM优化问题的目标函数记为:
那么我们可以将约束改写为,SVM在优化过程中选用的hinge form就是将约束中的大于等于改写为等于,即:
因此,优化目标函数就变为:
上式就是SVM求解目标函数的最终形式,可称为hinge form of SVMs。
- Transformations of variables:如果函数为单调递增函数,那么凸优化问题等价于:
优化方法中的最大似然估计MLE就采用log函数对目标函数进行变换,就是采用的这个思想。
- Introducing slack variables:凸优化可以通过引入松弛因子(slack variables)来消除约束(constraints)中的不等式,我们可以把凸优化问题转换为:
SVM算法都引入slack variables来允许训练误差的出现,防止模型过拟合。
5. 凸优化问题分类
凸优化问题根据目标函数和约束函数的形式分为:
- linear programs:线性规划;
- Quadratic programs:二次规划;
- Semidefinite programs:半正定规划;
- Cone programs:锥规划。
Ryan教授给了一个非常形象的例子来解释凸优化问题在优化问题领域的位置,以及以上几种优化问题间的关联关系,如下图:
线性规划问题(LPs)定义是优化问题满足以下形式,线性规划的实例包括diet problem, transportation problem, basis pursuit和Dantzig selector等:
二次规划问题(QPs)定义是优化问题满足以下形式,二次规划的实例包括portfolio optimization, lasso, SVM等:
其中,是半正定。这里需要注意的是,当Q不是半正定的时候,上述问题则不属于凸优化问题。同样,当时,二次规划问题就变为线性规划问题。
半正定规划问题(SDPs)定义是优化问题满足以下形式:
其中,,同时,。从上面的定义可以看出,和线性规划的定义基本一样,这里SDPs要求为矩阵,而LPs为向量,所以线性规划一定隶属于半正定规划的一个特例。