AI遮天传 ML-SVM入门

支持向量机(Support Vector Machine,SVM)是Corinna Cortes和Vapnik等于1995年首先提出的,它在解决小样本、非线性及高维模式式识别中表现出许多特有的优势,并能够推广应用到函数拟合等其他机器其学习问题中。 

背景信息:

  • 支持向量机 (Support Vector Machine,SVM)
  • 当前版本的支持向量机大部分是由Vapnik和 他的同事在AT&T贝尔实验室开发的
  • 是一个最大间隔分类器(Max Margin Classifier)
  • 最开始提出是做分类,后来很快被应用到了回归和时间序列的预测
  • 最有效的监督学习方法之一
  • 曾被作为文本处理方法的一个强基准模型(strong baseline)

生活引入:

我们生活中经常看到一些影评、物评等等,可以分成三类:

AI遮天传 ML-SVM入门_第1张图片 

  • Pos正面:这款游戏真好玩!
  • Neg负面:呸,狗都不玩。
  • Neural中性:这是一款像素游戏。

又如我们直到飞机、火车长什么样子,能够在不同的图片将它们分类出来:

AI遮天传 ML-SVM入门_第2张图片

再或者我们听一个音乐的音律、节奏,可以辨别出它是何种音乐,如:

AI遮天传 ML-SVM入门_第3张图片  

  • Rock:  Michael Jackson “Beat it”
  • Hip Hop:  Eminem “Lose yourself”
  • Blues:  Muddy Waters “I can’t be satisfied

对于以上三个例子,我们不难发现,都有一个“中性”的结果,其两侧分别是问题的两种不同的结果,这便是我们今天介绍的 线性向量机 解决问题的思路。

分类方法回顾:

决策树

  • 样本的属性非数值
  • 目标函数是离散的

贝叶斯学习

  • 样本的属性可以是数值或非数值
  • 目标函数是连续的(概率)

K-近邻

  • 样本是空间(例如欧氏空间)中的点
  • 目标函数可以是连续的也可以是离散的

支持向量机 (Support Vector Machine)

  • 样本是空间(例如欧氏空间)中的点
  • 目标函数可以是连续的也可以是离散的

 

一、线性支持向量机

给定一个训练样本的集合  gif.latex?%5Cdpi%7B100%7D%20%28x_%7B1%7D%2Cy_%7B1%7D%29%2C%28x_%7B2%7D%2Cy_%7B2%7D%29%2C%28x_%7BN%7D%2Cy_%7BN%7D%29%2Cx_%7Bi%7D%5Cepsilon%20%7B%5Ccolor%7BRed%7D%20R%5E%7Bn%7D%7D%2Cy%5E%7Bi%7D%5Cepsilon%20%7B-1%2C1%7D  

找到一个函数f(x,a) 分类样本,a为参数,使得:

gif.latex?%5Cdpi%7B100%7D%20f%28x_%7Bi%7D%2Ca%29%5Cleft%5C%7B%5Cbegin%7Bmatrix%7D%20%3E0%20%26%20%5Cforall%20y_%7Bi%7D%3D+1%5C%5C%20%3C0%20%26%20%5Cforall%20y_%7Bi%7D%3D-1%20%5Cend%7Bmatrix%7D%5Cright.         

AI遮天传 ML-SVM入门_第4张图片

则对于一个测试样本x,我们可以预测它的标签为[f(x,a)]

f(x,a) = 0 被称为分类超平面

解释:简单来说就是对于任意+1 正例 的部分,它全部都是大于0的;对于任意-1 负例 的部分,它全部都是小于0的。 电影评价,中评为 分类超平面 ,比中评好的,我们分类为好评,比它差的,我们分类为差评。

线性分类器:

对于一个线性超平面:

gif.latex?%5Cdpi%7B100%7D%20f%28x%2C%5Calpha%20%2Cb%29%20%3D%20%3Cx%2C%5Calpha%3E%20+%20b%20%3D%200 

(注:gif.latex?%5Cdpi%7B100%7D%20%3Cx%2C%5Calpha%3E为向量gif.latex?%5Cdpi%7B100%7D%20x%2C%5Calpha的内积即样本特征值和参数的内积,b为截距。)

在线性可分的情况下,有无穷多个满足条件的超平面,把结果分成n部分(n=2那分类超平面就是一条线,n=3就是一个面...)

AI遮天传 ML-SVM入门_第5张图片

那么哪条线最好呢?

线性分类器的间隔(Margin)

  • 在分类分界面两侧分别放置平行于分类超平面的一个超平面 ,移动超平面使其远离分类超平面
  • 当他们各自第一次碰到数据点时,他们之间的距离被称为线性分类器的间隔
  • Margin (间隔): 分界在碰到数据点之前可以达到的宽度

AI遮天传 ML-SVM入门_第6张图片

比如黑线是超平面,两条黄线的边界刚刚触碰到各自的第一个点,上面宽为2,下面宽为3,那间隔就是5.

 

最大间隔线性分类器 (Maximum margin linear classifie)

即具有最大间隔的线形分类器

AI遮天传 ML-SVM入门_第7张图片

我们看到这次的黑线(超平面)两端的黄线明显更粗了,所以这条线更好。

那些阻挡间隔继续扩大的数据点,我们叫做支持向量(SV)。

(除了间隔边界上的数据点以外,那些在间隔区域内的、 以及在错误一侧的数据点,也都是SV。后面会讲)

 

问题形式化

首先,我们需要数据点完美分布在超平面两侧,

gif.latex?%5Cdpi%7B100%7D%20f%28x_%7Bi%7D%2Ca%29%20%3D%20%3Cx%2C%5Calpha%3E%20+%20b%5Cleft%5C%7B%5Cbegin%7Bmatrix%7D%20%3E0%20%26%20%5Cforall%20y_%7Bi%7D%3D+1%5C%5C%20%3C0%20%26%20%5Cforall%20y_%7Bi%7D%3D-1%20%5Cend%7Bmatrix%7D%5Cright.

引入平行于分类超平面的两个额外超平面:

gif.latex?%5Cdpi%7B100%7D%20%3Cx%2C%5Calpha%3E%20+%20b%20%3D%20%5Cpm%201  

AI遮天传 ML-SVM入门_第8张图片

 间隔即两个新的超平面gif.latex?%5Cdpi%7B100%7D%20%3Cx%2C%5Calpha%3E%20+%20b%20%3D%20%5Cpm%201 之间的距离

AI遮天传 ML-SVM入门_第9张图片

如何计算 gif.latex?%5Cdpi%7B100%7D%20%5Crho_%7B1%7D%5C%2C%20%5C%2C%20%5Crho_%7B2%7D ?

AI遮天传 ML-SVM入门_第10张图片

最优化问题(使间隔最大化):

AI遮天传 ML-SVM入门_第11张图片

虽然看起来似乎间隔只与w有关, 但b仍然通过约束w的取值,间接对间隔产生影响。

(因为y为1或-1,gif.latex?%5Cdpi%7B100%7D%20y_%7Bi%7D%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29%5Cgeq%201 说明都分对了)

 

对偶问题(拉格朗日子乘法)

AI遮天传 ML-SVM入门_第12张图片

AI遮天传 ML-SVM入门_第13张图片

即经过一系列的转化,我们最终要求的就是在上图红色部分中,在二三行条件下,第一行的最小值。

 

支持向量

根据KKT条件:gif.latex?%5Cdpi%7B100%7D%20%5Calpha%20_%7Bi%7D%28y_%7Bi%7D%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29-1%29%3D0    (gif.latex?%5Cdpi%7B100%7D%20%5Calpha%20_%7Bi%7D>=0)

  1. 当 gif.latex?%5Cdpi%7B100%7D%20%5Calpha%20_%7Bi%7D 非0 ---> gif.latex?%5Cdpi%7B100%7D%20y_%7Bi%7D%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29-1%3D0  即gif.latex?%5Cdpi%7B100%7D%20x_%7Bi%7D在间隔的边界上(支持向量SV)
  2. 大多数 gif.latex?%5Cdpi%7B100%7D%20%5Calpha%20_%7Bi%7D为0,这些gif.latex?%5Cdpi%7B100%7D%20%28x_%7Bi%7D%2Cy_%7Bi%7D%29gif.latex?%5Cdpi%7B100%7D%20f%28x%29没有什么影响  稀疏解

AI遮天传 ML-SVM入门_第14张图片

 

线性不可分情况

我们前面提到:首先我们需要数据点完美分布在超平面两侧,这是为了保证训练分类错误率为0.

但是在线性不可分情况下,一定会有错误。

77cab4c7082b49d8b81bdae535de410d.png

此时找不出一条直线来将他们分隔开来。

我们需要最小化 gif.latex?%5Cdpi%7B100%7D%20%5Cbegin%7BVmatrix%7D%20%5Comega%20%5Cend%7BVmatrix%7D_%7B2%7D%5E%7B2%7D 和 训练分类错误!

gif.latex?%5Cdpi%7B100%7D%20%5Cunderset%7B%5Comega%20%2Cb%7D%7Bmin%7D%5Cfrac%7B1%7D%7B2%7D%5Cbegin%7BVmatrix%7D%20%5Comega%20%5Cend%7BVmatrix%7D_%7B2%7D%5E%7B2%7D+C%20*%20%28loss%5C%2C%20%5C%2C%20for%5C%2C%20%5C%2C%20errors%29

其中C>0 是一个用于平衡这二者的常数(前面重要C小一点 后面重要C大一点)

正值常数 C 平衡着 大间隔和小分类错误

Structure risk (结构风险) vs. empirical risk (经验风险)

  • 大 C: 更偏向于错误小
  • 小 C: 更偏向于间隔大

损失函数: 0/1 损失 和 Hinge 损失

回顾正确的预测: gif.latex?%5Cdpi%7B100%7D%20y_%7Bi%7D%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29%20%5Cgeq%201

定义gif.latex?%5Cdpi%7B100%7D%20z_%7Bi%7D%5Coverset%7B%5CDelta%20%7D%7B%3D%7Dy_%7Bi%7D%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29

对每个样本gif.latex?%5Cdpi%7B100%7D%20x_%7Bi%7D:

  • 0/1损失:

        1%7D%20%5Coverset%7B%5CDelta%20%7D%7B%3D%7D1%28z_%7Bi%7D%3C0%29        非凹凸连续,不容易求解

z<0时:gif.latex?%5Cdpi%7B100%7D%20y_%7Bi%7D<0时gif.latex?%5Cdpi%7B100%7D%20%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29>0 或 gif.latex?%5Cdpi%7B100%7D%20y_%7Bi%7D>0时gif.latex?%5Cdpi%7B100%7D%20%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29%3C0  说明做错了/正例跑到了负例那,负例跑到了正例那。此时loss=1

z>=0时:loss=0

  • Hinge损失:

        gif.latex?%5Cdpi%7B100%7D%20l_%7Bhinge%7D%28z_%7Bi%7D%29%5Coverset%7B%5CDelta%20%7D%7B%3D%7Dmax%280%2C1-z_%7Bi%7D%29

z<1时,说明点在间隔里面,loss=1-z

z>=1时,loss=0,说明对了

AI遮天传 ML-SVM入门_第15张图片

更多损失函数:

AI遮天传 ML-SVM入门_第16张图片

 

形式化损失函数

AI遮天传 ML-SVM入门_第17张图片

 

软间隔(soft margin)

AI遮天传 ML-SVM入门_第18张图片

仍然希望找到最大间隔超平面,但此时:

  • 我们允许一些训练样本被错分类(gif.latex?%5Cdpi%7B100%7D%20y_%7Bi%7D%28%3Cx%2C%5Comega%20%3E%20+%20b%20%29%5Cgeq%201%20-%20%5Cvarepsilon, 不一定全分对了)
  • 我们允许一些训练样本在间隔区域内(是正确的,这次不停下来)
  • gif.latex?%5Cvarepsilon%20_i%20%3D%200 时,数据点在间隔区域的边界上 或 在间隔区域外部正确分类的那一侧
  • gif.latex?0%3C%5Cvarepsilon%20_%7Bi%7D%5Cleq%201 时,数据点在间隔区域内但在正确分类的一侧
  • gif.latex?%5Cvarepsilon_%7Bi%7D%3E1 时,数据点在分类超平面错误分类的一侧

正值常数 C 平衡着 大间隔和小分类错误

    Structure risk (结构风险) vs. empirical risk (经验风险)

  • 大 C: 更偏向于错误小
  • 小 C: 更偏向于间隔大

 

对偶问题总结

AI遮天传 ML-SVM入门_第19张图片

 

应用举例: 利用LLC 和 SVM的图像分类

数据集: Caltech101 :9144 张图片、102 类别

预处理:转化为灰度图、放缩图片 e.g. 较长边有120 像素

用LLC (底层特征,Low Level Content) 来提取图像特征

用SVM训练和测试

测试结果

  • 训练时每个类别用 15 张图片: 70.16%
  • 训练时每个类别用 30 张图片: 73.44%

AI遮天传 ML-SVM入门_第20张图片

 

二、核函数支持向量机 (Kernel SVM)

从输入空间到特征空间    gif.latex?%5Cphi%20%28x%29%3AR%5E%7Bn%7D%5Crightarrow%20F

样本xi 在输入空间线性不可分,但可能在特征空间中线性可分。

AI遮天传 ML-SVM入门_第21张图片

 

特征空间中的问题

AI遮天传 ML-SVM入门_第22张图片

核技巧 (Kernel Tricks)

为了在特征空间中求解对偶问题且找到分类超平面,我们只需知道 gif.latex?%3C%5Cphi%20%28x%29%2C%5Cphi%20%28y%29%3E,(而不是分别的gif.latex?%5Cphi%20%28x%29%2C%5Cphi%20%28y%29。)

如果我们已知一个函数 gif.latex?k%28x%2Cy%29 它等于 gif.latex?%5Cphi%20%28x%29%2C%5Cphi%20%28y%29 那么我们就没有必要显示地表示这些特征。

gif.latex?k%28x%2Cy%29 称作 核函数(kernel function)

即只需要知道核函数是什么就好了。

 

常用核函数

AI遮天传 ML-SVM入门_第23张图片

 

例如:

a3b93f58f31c48a1be89f3053c41c106.png

即他们地映射结果刚好是相等的所以可以用核函数代表。

 

三种构造核函数的方法

AI遮天传 ML-SVM入门_第24张图片

注:是三种方法;

  • 第一种:根据特征函数手动计算核函数
  • 第二种:直接选择一个合理的核函数
  • 第三种:利用简单核函构造新的核函数

举例: 构造高斯核函数

AI遮天传 ML-SVM入门_第25张图片

软件工具

Libsvm :http://www.csie.ntu.edu.tw/~cjlin/libsvm/

Liblinear :http://www.csie.ntu.edu.tw/~cjlin/liblinear/

SVMlight :http://svmlight.joachims.org/

 

三、SVM的核心概要 

线性支持向量机

  • 线性可划分问题:最大化间隔
  • 线性不可划分问题:最大化间隔且最小化分类错误
  • 原始问题不好求,转换为对偶问题。

核函数支持向量机

  • 映射到特征空间:gif.latex?%5Cphi%20%28x%29%3AR%5E%7Bn%7D%5Crightarrow%20F
  • 核技巧:gif.latex?k%28x%2Cy%29%3D%3C%5Cphi%20%28x%29%2C%5Cphi%20%28y%29%3E
  • 3种构造核函数的办法 

SVM的优缺点

优点

  • 很好的数学基础
  • 最大化间隔使得方法的鲁棒性非常高,泛化能力强
  • 用线性的方法解决线性不可分问题(两种思路)
  •       1.利用soft margin: 最大化间隔且最小化分类错误
  •       2.通过从输入空间到特征空间的变换
  •              本质上是将在低维空间上线性不可分的问题,通过变换(大多是升维)变成线性可分问 题
  •               利用Kernel Trick, 并不需要知道该变换是什么
  •        在实际应用中效果往往不错

缺点

  • 有多种核函数可用,针对具体问题,哪个核函数最好?

                —— 尚未找到理论上可证 明的最优选择 

 

 

你可能感兴趣的:(机器学习,python,svm,人工智能)