支持向量机|机器学习推导系列(七)
一、硬间隔SVM
- 模型定义
假设有以下数据:
SVM的主要思想是在特征空间中寻找一个最大间隔的超平面实现数据的二分类,SVM属于判别模型。这里的间隔指的是样本点到分离超平面的距离的最小值,用函数来表达。下图中在和线上的样本点就叫支持向量:
支持向量机超平面实现将数据的正例和负例分隔开,因此有:
另外最大间隔通过以下方式来表达:
然后求解支持向量机就可以转化为以下带约束的优化问题:
上述优化问题还可以进一步转化:
由此上述优化问题转化为:
这是一个带N个约束的凸优化问题。
- 优化问题的转化
上述优化问题可以使用拉格朗日乘子法来求解,构建拉格朗日函数:
然后上述优化问题就可以转换为以下优化问题:
我们可以简单地看一下为什么可以这么转化:
然后使用以下结论继续对该优化问题进行转化:
因此该优化问题可以继续转化:
总结一下,该优化问题经历了以下转化过程:
- 模型求解
- 对求导
- 求解
这里我们可以看出是数据的线性组合。
- 得出
因此该优化问题就相当于:
也就相当于:
- KKT条件
首先定义该优化问题的KKT条件:
该优化问题满足上述KKT条件,这是由于以下定理:
KKT条件中也叫松弛互补条件,即和总有一个为0。也就是说只有支持向量对应的才可能有值(),而其他不在和上的样本点对应的一定为,该性质可以用来求出。
我们已经根据求出了,接下来要求出,我们可以通过求解来得出各个,而这个过程也是支持向量机算法计算量最大的地方,这里我们就不展示过程了。
找出求解得到的不等于的,也就是支持向量对应的,假设其中一个支持向量为,则有,最终可以解得:
二、软间隔SVM
我们的训练数据通常不是理想的线性可分,有时甚至是线性不可分的数据。对于存在噪声的一些数据,我们应该允许一点分类错误,因此我们需要对目标函数进行一些调整:
- 使用误分类点的个数作为loss
显然使用的指示函数是不连续的,不利于求解,所以不使用这种loss函数。
- 使用距离作为loss
该函数为合页损失函数(hinge loss),令,则对的图像如下:
合页损失函数- 软间隔SVM的优化问题
引入,则该优化问题转化为:
上面的式子中,常数可以看作允许的错误⽔平,同时上式为了进⼀步消除符号,对数据集中的每⼀个观测,我们可以认为其⼤部分满⾜约束,但是其中部分违反约束,因此这部分约束变成。
软间隔SVM也是使用拉格朗日乘子法进行求解。