什么是支持向量机-SVM


支持向量机-SVM(Support Vector Machine)从本质来说是一种:用一条线(方程)分类两种事物。

有了直观的感知,在定义这一节在做一些深入的思考,分解名词(Support Vector Machine)并尝试解释:


公式中每一个符号的含义在后文有说明

2 如何求解支持向量机


对于我们需要求解的这个超平面(直线)来说,我们知道

  • 它离两边一样远(待分类的两个部分的样本点)

  • 最近的距离就是到支持向量中的点的距离

根据这两点,抽象SVM的直接表达(Directly Representation)

其实这个公式是一点也不抽象,需要更进一步的用符号来表达。

我们知道在准确描述世界运行的规律这件事上,数学比文字要准确并且无歧义的多,文字(例子)直观啰嗦,数学(公式)准确简介。

         硬间隔         


SVM支持向量机


注:公式中加粗或者带有向量箭头的都表达一个向量


注:s.t. :subject to 表示约束条件,表达的意思等价于:为了使得所有样本数据都在间隔区(两条虚线)以外。

为了解(3)式,需要用到拉格朗日乘子法(Method of lagrange multiplier),它是用来求解在约束条件目标函数的极值的。

注:以下解算过程中很多地方推导过程只写必要过程及结论



         软间隔         

已经说明了如何求得方程,以上的推导形式都是建立在样本数据线性可分的基础上,如果样本数据你中有我我中有你(线性不可分),应该如何处理呢?这里就需要引入软间隔(Soft Margin),意味着,允许支持向量机在一定程度上出错。

三种常见损失函数如下图


(8)式就是常见的软间隔支持向量机,其中,每一个样本都有一个对应的松弛变量,用以表征该样本不满足约束的程度,求解的方法同理硬间隔支持向量机。

3 支持向量机扩展


         核方法         

以上我们求解的支持向量机都是在线性情况下的,那么非线性情况下如何处理?这里就引入:核方法

对于这样的问题,可以将样本从原始空间映射到一个更高为的特征空间,使得样本在这个特征空间内线性可分


         多类问题         

多类问题可以使用两两做支持向量机,再由所有的支持向量机投票选出这个类别的归属,被称为one-versus-one approace


©著作权归作者所有:来自51CTO博客作者mob604756f42bbf的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. 面试时如何回答购物车测试步骤?
  2. 技巧分享:如何利用CSS属性修改图片颜色?
  3. 【直观详解】信息熵、交叉熵和相对熵
  4. 数据处理不等式:Data Processing Inequality
  5. 什么是Python,如何安装使用Python
  6. ui设计要学插画吗?
  7. 码农要失业了,微软开源了 Sketch2Code 教你 AI 编程
  8. [DM]分类-支持向量机
  9. 如何在Safari中删除Cookie?

随机推荐

  1. Android编译系统中的Kconfig,Makefile,.co
  2. Android NDK: Your APP_BUILD_SCRIPT poi
  3. android gallery的使用
  4. Android 7.1.2(Android N) Activity启动
  5. android 学习笔记(四)
  6. 关于Android如何禁止屏幕旋转刷新界面
  7. Android 动画小知识点
  8. android之启动桌面activity
  9. Android文件操作
  10. Android ------ 拍照相册选择图片 剪裁图