SVM发展史#
线性SVM=线性分类器+最大间隔#
间隔(margin):边界的活动范围。The margin of a linear classifier is defined as the width that the boundary could be increased by before hitting a data point.
预备知识#
-
线性分类器的分割平面(超平面):
Wx+b=0
- 点到超平面的距离:,其中
- SVM中正样本定义为g(x)>=1,负样本定义为g(x)<=-1
- SVM中Wx+b=1或者Wx+b=-1的点称为支持向量
间隔的形式化描述#
SVM通过最大化M
来求解参数W
和b
的,目标函数如下:#
data:image/s3,"s3://crabby-images/f755f/f755fafe0bf97ddbc4a5ba315bcb4ec349a1c099" alt=""
求解 :拉格朗日乘数法,偏导为0后回带#
data:image/s3,"s3://crabby-images/27d23/27d23283cc4003395ed117e8d5f8c01cb847b4a3" alt=""
在SVM中,原问题和对偶问题具有相同的解,W已经求出:, 不等式约束,还需要满足KKT条件。若,则必有xi为支持向量,即:训练完毕后,最终模型仅和支持向量有关。
data:image/s3,"s3://crabby-images/61095/610952c1e4a1dd22262aaf1353adb8c502c8a8cb" alt=""
b的求解过程如下
data:image/s3,"s3://crabby-images/28e6f/28e6f901e9d32302b6507303656ebe02a522af52" alt=""
一个实例#
data:image/s3,"s3://crabby-images/f6ba3/f6ba35bfbc1133e68fce10dbd0eb94e5bb861363" alt=""
软间隔:加入容错量#
data:image/s3,"s3://crabby-images/58594/5859453d2c31b74b5790f364f77b52deaab986cf" alt=""
同样采用拉格朗日乘数法求解#
LD的区别仅仅体现为的约束不同。
data:image/s3,"s3://crabby-images/5eb7b/5eb7b78d1b19c091e4557be3d8b40ab46b3733c1" alt=""
非线性SVM:特征空间#
通过映射到高维空间来将线性不可分的问题转换为线性可分的问题。
data:image/s3,"s3://crabby-images/314f6/314f68cd9ae0d12cd1a04b5918e11c1d137691f6" alt=""
高维空间向量内积运算复杂度高。以二次型为例,直接计算#
,直接计算的话,复杂度会成倍增加。
data:image/s3,"s3://crabby-images/ba54d/ba54d67398217d34b4df151e9472a6b1d7b6f062" alt=""
以二次型为例,理解核技巧#
通过在低维空间的计算o(m),得到高维空间的结果,不需要知道变换是什么,更不需要变换结果的内积,只需要知道核函数,就可以达到相同的目标。(变换结果的内积)
data:image/s3,"s3://crabby-images/306f9/306f907a4b1c94e1eafd7b22a044b89a5c08fbfc" alt=""
请看实例,二维空间#
data:image/s3,"s3://crabby-images/3fff0/3fff0d35e95e5ca3c032466614c7f6846dcd8b13" alt=""
常用的核函数#
多项式变换中,当d=2时,就是二次型变换。
data:image/s3,"s3://crabby-images/17f49/17f499828612f1743996046fb6c366c5348c6c8e" alt=""
此时w和b的结果如下:#
将换为,将换为,其余都不变,真的很简洁。
data:image/s3,"s3://crabby-images/63095/630957fb5603a17c24fbad40b529f3cf83812d8e" alt=""
SVM在Scikit-Learn中的应用#
- Linear SVM:
LinearSVC( penalty='l2', C=1.0,#就是目标函数的C,C越大(eg:1e9),容错空间越小,越接近硬边界的SVM(最初的SVM,基本不用),C越小(eg:C=0.01),容错空间越大,越接近soft Magin. )
-
核函数 SVM:
from sklearn.svm import SVC
SVC( C=1.0, kernel='rbf', degree=3,#多项式核函数的指数d gamma='scale',#高斯基函数中的参数gamma,越大,函数分布越狭窄; gamma越小,决策边界越松弛,当很小时,可以认为趋于无穷大成一条直线了,这时就欠拟合了。gamma取值越大,决策边界越收紧,当很小时,会无限包紧样本点,这时就过拟合了。 )