支持向量机一:线性可分问题
支持向量机(SVM)是一种二类分类模型,通过定义在特征空间上的间隔最大分类器从而有别于感知机模型。
线性可分支持向量机与硬间隔最大化
给定一个特征空间上的训练集:
T={(x1,y1),(x2,y2),⋯,(xN,yN)}
其中 xi∈Rn , yi∈{+1,−1}。
若训练集是线性可分的,我们就可以找到一个分离超平面将所有的实例点分到不同的类去。在之前的感知机的学习中,我们可以通过迭代调整的方式得到最终的分离超平面,但是对于不同的初值,得到的结果是不唯一的。我们通过定义函数间隔与几何间隔的方式来找出最好的分离平面。
函数间隔与几何间隔
对于一个分离超平面 0=ω⋅x+b, ∣ω⋅xi+b∣ 是实例 xi 到分离平面的距离。一般来说,距离越大说明分类的可信度越高,因此函数间隔就可以定义为:
γ^i=yi(ω⋅xi+b)
而超平面关于训练集 T 的函数间隔就定义为 γ^=minγ^i ,通过所有实例到超平面距离的最小值来衡量该分类器的好坏
对于距离进行规范化即 γ=∣∣ω∣∣γ^ ,就得到了几何间隔,避免了因为系数的等比例放大导致的尺度不统一。
间隔最大化
前面讲了,支持向量机模型不同于感知机的最大特点就在于选择了几何间隔最大化的超分离平面,可以将我们的分类问题,转化为如下的优化问题:
ω,bmaxs.t.γyi∣∣ω∣∣ω⋅xi+b≥γ,i=1,2,⋯,N
由于 γ^=∣∣ω∣∣γ,并且函数间隔的实际取值并不影响优化结果,不妨取 γ^=1 ,那么原优化问题可以转化为:
ω,bmaxs.t.∣∣ω∣∣1yi(ω⋅xi+b)≥1,i=1,2,⋯,N
也等价于
ω,bmins.t.21∣∣ω∣∣2yi(ω⋅xi+b)≥1,i=1,2,⋯,N
这样,我们就将原问题转化为了一个凸优化问题。求解得到 ω∗,b∗。
对偶问题的优化
应用拉格朗日对偶性来解决最优化问题,由于原始问题是凸优化问题,因此可以通过对偶问题来得到原始问题的最优解。
首先给出拉格朗日函数:
L(ω,b,α)=21∣∣ω∣∣2+i=1∑Nαi−i=1∑Nαiyi(ω⋅xi+b)
其中拉格朗日乘子 αi≥0
原始问题的对偶问题即为;
αmaxω,bmins.t.L(ω,b,α)αi≥0
首先求 minω,bL(ω,b,α)。通过求梯度为零的点,得到:
ω−i=1∑Nαiyixi=0−i=1∑Nαiyi=0
代回可以得到:
ω,bminL(ω,b,α)=21i=1∑Nj=1∑Nαiαjyiyjxi⋅xj+i=1∑Nαi−i=1∑Nj=1∑Nαiαjyiyjxi⋅xj=i=1∑Nαi−21i=1∑Nj=1∑Nαiαjyiyjxi⋅xj
则对偶问题被转化成:
αmins.t.21i=1∑Nj=1∑Nαiαjyiyjxi⋅xj−i=1∑Nαii=1∑Nαiyi=0αi≥0,i=1,2,⋯,N
处理该优化问题,得到对偶问题的可行解 α∗ ,对于原始问题的可行解:
ω∗=i=1∑Nαiyixi
由于 α∗ 必然不是 0 (显然最优解存在 αj>0,由KTKT条件 yj(ω∗⋅xj+b∗)−1=0,可以得到:
b∗=yj−i=1∑Nαiyixi⋅xj
支持向量与间隔
我们发现,在模型训练的过程中,最终只有 αi>0 的实例点决定了分离超平面。在可视化图形中,这些间隔点是距离分离超平面最近的几个实例点,称为支持向量,而由经过支持向量且平行于分离超平面的两个超平面之间构成的空间就称之为该模型的间隔。
软间隔最大化
以上构建的模型建立在训练集线性可分的基础上,但线性可分实际上是一个很强的前提,因此考虑引入一个对于间隔的松弛变量 ζ,对于两个类别中的极端个例,允许出现在间隔中,甚至被误分类。
引入松弛变量,原始问题就变为:
mins.t.21∣∣ω∣∣2+Ci=1∑Nζiyi(ω⋅xi+b)≥1−ζi,i=1,2,⋯,Nζi≥0,i=1,2,⋯,N
在这个问题中 C 是惩罚参数,即模型允许存在误分类,但是目标函数中会对误分类进行惩罚,最终通过最优化达到平衡。
对偶问题
该问题求对偶问题的方式基本上是一致的,首先得到原始的对偶问题:
α,βmaxω,b,ζmins.t.21∣∣ω∣∣2+Ci=1∑Nζi+i=1∑Nαi(1−ζi)−i=1∑Nαiyi(ω⋅xi+b)−i=1∑Nβiζiαi≥0,βi≥0
首先求极小值:
∇ωL∇bL∇ζiL=ω−i=1∑Nαiyixi=0=−i=1∑Nαiyi=0=C−αi−βi=0
代回可以将原问题转化为:
αmins.t.21i=1∑Nj=1∑Nαiαjyiyjxi⋅xj−i=1∑Nαii=1∑Nαiyi=0C=αi+βiαi≥0,βi≥0,i=1,2,⋯,N
通过等式约束消去 βi 来约束变量可以得到
αmins.t.21i=1∑Nj=1∑Nαiαjyiyjxi⋅xj−i=1∑Nαii=1∑Nαiyi=00≤αi≤C
通过解这个最优化问题,得到 α∗ ,以线性可分问题类似的方式可以得到 ω∗,b∗