SVM-支持向量机原理详解与实践之二
2017-03-14 22:27
435 查看
SVM-支持向量机原理详解与实践之二
因为通过应用拉格朗日对偶性我们可以寻找到最优超平面的二次最优化,
所以以下可以将寻找最优超平面二次最优化(原问题),总结为以下几个步骤:
在原始权重空间的带约束的优化问题。(注意带约束)
对优化问题建立拉格朗日函数
推导出机器的最优化条件
最后就是在对偶空间解决带拉格朗日乘子的优化问题。
注:以上这个四个步骤是对优化问题的的概括,后面会注意讲解这几个步骤。
于是首先想到的几个随之而来的几个问题:
第一个问题是拉格朗日对偶性是什么?
第二问题是为什么拉格朗日对偶性可以帮助我们找到最优超平面的二次最优化?
第三个问题是如何运用拉格朗日对偶性找到最优超平面的二次最优化?
下面的内容将对以上三个问题进行深入的分析。
首先对于第一个问题,我们首先必须清楚两个概念即原问题和对偶问题,以及他们之间的关系.
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/afb339889270685c289252a1871542c6)
是定义在
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/16a1ce57577492feabfd9c9ac6e19cd2)
上的连续可微函数,考虑约束最优化问题:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/edd993b9aaafed358e3344a2ffead784)
称为约束最优化问题的原问题。注意必须是连续可微的。类似的对比我们之前分析的最优超平面的二次最优化问题:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/71d95c42d2121bc3a23347fad23c6680)
其中
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/68ae88b7f86e8f475d1cefc4856c5dda)
就为
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/9b5a05cd9291d2940b4462c3f0136963)
,约束条件
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2ff611d2923e07e11887fbd5d054b402)
对应的就是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/01c95bc5caab2179e8300f0d6b1ff447)
,都是带约束的最优化问题。如果是不带约束(没有后面的约束条件)我们知道可以直接对
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ae9f0065a2479617a8d1a1287e4e28e2)
直接求偏导,即可解出最优解。
但是如何把带约束的原始问题转化为不带约束的原问题呢?拉格朗日函数就是解决这个问题的,于是我们引入广义的拉格朗日函数:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/8aef39ecd653b6b818291ce4e4e72712)
其中
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/79a04ae5dbec54c4b22ee267d9732646)
是拉格朗日乘子,需要注意的是约束条件
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/dcb7fb5b3c27f3f28ce0832c687b1edc)
。
如果我们把上面这个广义的拉格朗日函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/af3a7f7d0b173a75e71b5fe20a5fb8a5)
看做是一个关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/dd7f1eedffb38cd908154e2c3b7a0217)
的函数,于是要求求解这个关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/0757e02f7c60bf84d40e64f3f10b9fe6)
的函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7166e3d93a3e8f4dee6a28ff79fb46fc)
的极大值,表示如下:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e40899f70d4c9fdf63ff036ef83d7bfa)
要求解上式,我们可以将
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e34288f06f6edc0b7aea75759139ae27)
看做常数,求解出一对
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/34d2c3b1e7db25853bb7441fb533ca8a)
使得
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e36b30d7b5527aaab1ccf47ee8a8c0ad)
得极大值,求出这一对
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/068241ce5953e8ba0fd475386a6f1123)
后,又由于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/bf641d43cb8bef64e9288d52ab499764)
已经确定,很显然的:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/cb7c49a8fe89f46ba6c7d768cfbeeed4)
只是一个和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7deb8d0380f0318ecb683d5118ba0a8c)
有关的函数,我们将这个函数定义为:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d59c11b5eb18a2a8dd83755b39a3ab16)
这里
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1bc23f5f2fd4d74f11447d97e2847602)
中的P下标表示"primal"。让我们假设
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7c6fdf9fc3d1e880ad59c3200aee9080)
已经给定,我们可以通过是否满足约束条件来分析这个函数。
情况一:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2aaa99012faa3cca5495884196397182)
违反了原始的约束,也就是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3acfe33e59190331bcb9e60cf52a84ca)
或是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/9b00052a1d032d937443de4f3d24b18f)
,如下:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/96c75e32bb1d4febc217dabe2c81ada4)
有前面的定义可知
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e1216d3c1d87a4ba86cc9fe9cda722fc)
,又由于违反了原始的约束,也就是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/079438cf9b8fd51e8bfcc8abfd521578)
或是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/9ec8f44833eb3514420f208dd65c8828)
这个情况,所以很容易通过取拉格朗日乘子
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6f6af1541ef471f52023074c94a0bc59)
的值使得
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3d13af2b589b44a130061e6b2f006e4a)
,也就是:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/69f1b42310a91dff2ddd7d4578b312da)
情况二:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/48a9e0da09977230af48a8d08d03d157)
满足原始的约束,也就是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e4784b23b90746503a2c9a9d7d59ee07)
或是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/adcb95ea62a8f8e9bf62deead4c29188)
,所以:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6e1c46f593be51acba3e90f0f4fb65b1)
注意要想使得
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b10f23146ca258a611238790b98376e5)
最大化,由于满足约束条件
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/8abd112c8acca399f5aeb1fbf0cc7758)
或是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/72d54c305d7774a766b2e205cf8c336f)
,其实就是后面两个式子就等于0,又由于在最大化的过程中
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/4b1d22ea839a8947d7c0006067e114ff)
为常数,常数的最大值就是本身,所以:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/68b814ddb461749b885ff3651c2dd14d)
通过上述的分析我们可以总结
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f9dfcd7a2699a178966904881e686083)
,也就是:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/df2b586266b1923c63ed439d7b7b3d0a)
上面分析了原问题
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/4c5cfb1dca461f59a974b0ea3182007d)
在
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/67c9beadb4b3a7fc59efd12922f19ed2)
满足原始的约束和不满足原始约束的情况下的取值,那么如果是在满足原始约束的条件下面我们考虑最小化
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d6125e4c3653e7278ed0b7d30f019a5e)
的问题:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/62c9eb73616ef7c12674acee1b56cd47)
也即:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ed5fc485e45cab3c9093ad511d2058a1)
是的,到这里我们发现
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/0ffe9a2038eb743389db67546241fa64)
和我们前面定义的原问题
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/a15a90083dba29852a81e9493b5899b4)
一样。它们是等价的,于是我们将原始问题的最优值定义为:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6649020859ec37a16cefa006edaa1aac)
总结:通过拉格朗日函数重新定义一个无约束问题,这个无约束问题等价于原来的约束优化问题,从而将约束问题无约束化!
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/eb07022419fadae74d4602aad4007c0f)
的函数:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6e5bea1b9074ad25ad65320bfb06a740)
这里的D是指'Dual' 即对偶,注意和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/bb7445ed7691bc7edcff831976bb454f)
是一个关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1b3e0b9e2148695042b374352ed8de24)
的函数不同,这里的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3a8b65e29cfb8f17544597d91d358704)
是一个关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ca5d5ec32d46da070398a578d78a40bb)
两个拉格朗日乘子的函数。等式的右边确定是关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/932496b338c059d926c7adb20a798e24)
的函数的最小化,当
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/5775984f2030877f7e7c7910264b280d)
确定以后,最小值只和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e83358e38c148418bb0d786d48e50271)
有关。
下面极大化
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ad494b23909c83f9ef37c31b267a5cc1)
,于是有:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/dbc03a102dcf88612b84c1e79428b9f0)
观察上式,对比原问题:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/78d5257d1639e0de71e6e863f11d53c6)
我们可以看到对偶问题是先最小化
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7d0aae81ebaa228829370b00cf1f0698)
再对结果取最大化,而原问题则相反,它们的区别在于:
原问题先固定
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/12f9ce0ab56c7e790deeaf623d6b7606)
中的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7d6567bab166bcd89a5e626a09a9075e)
,优化出参数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d5a8cd7ae0060d560ca3f4006f62f4b3)
,再优化出最优的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7cde4bf552be2fe0f48be4dc680e703c)
;
对偶问题则是先固定
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/29cb94da912a36fed6199f78732e516d)
,优化出最优的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c677e184bbe604be2c277dbbbbf5d117)
,最后确定参数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/dcf2e2d536d37ccbb7d9c6faa8bd7896)
。
为了方便讲解我们定义对偶问题的最优值为:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/66cf3096ca3d388e8ffee4aa2e4c9f62)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/69758e36dba73598f5b22b17d35b8cab)
证明:对任意
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/73ceebfd3a292d6fc80e4a97e1304b65)
有:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/a7df7b70971fdef42215edc040e5a520)
即:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e9b7a41fdb14b5e087f1d743725ac03b)
,
由于原始问题和对偶问题都有最优值,所以:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/fa49df843c6cb75f8f42588a32569b17)
即:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/8782938ac0bef464f906e3d7ce4af422)
也就是说原始问题的最优值不小于对偶问题的最优值,但是我们要通过对偶问题来求解原始问题,就必须使得原始问题的最优值与对偶问题的最优值相等,于是可以得出下面的推论:
推论:设
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1635c24c1abd3717817f6f8e9d391b9b)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/914b35ec690bb332dc2c93cc083929d7)
分别是原始问题和对偶问题的可行解,如果
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3d693089c2efaf7539b1151e5c856278)
,那么
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/8eab15747b0ce5133b2e2d25d3499733)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1deca3b87b54502f83cf59510e507e6b)
分别是原始问题和对偶问题的最优解。
到此我们通过对原问题和对偶问题,以及它们之间关系的了解,也就回答了前面提的第一个问题:拉格朗日对偶性是什么?
这里再次总结拉格朗日对偶性:即
如果原问题有最优解,对偶问题也有最优解,并且相应的最优值是相同的;
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/658570809210f43d32cf95fa856c2807)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e441da9a74ec54b2507bff2865818ac9)
是凸函数,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d32ede4cf2d22cf6d7854bd6f999db64)
是仿射函数(即由一阶多项式构成的函数,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/926d3bc03202973f2ccfc12abd202479)
),A是矩阵,b是向量);并且假设不等式约束
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2e2f7996e7d1afc59ef7adcdd6881404)
是严格可行的,即存在
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3932243595e6259f13cbd97463da4f1d)
,对所有
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e64cf18191db031a1b9ae78e18b0dd32)
有
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d560cb21aa559821c9b23ca950480d4c)
,则存在
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/85e50dd8ad12ed91068eaa9d1849fedc)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/57d50beed6869ccd656949cee2885ec5)
,使得
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3146eaf10de07f8dadf508844d5eb477)
是原始问题的最优解,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2303e61aea6c19d39968572b93e5a467)
是对偶问题的最优解,并且:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6bec27b5144efc08f536019e5aff854c)
定理:对于原始问题和对偶问题,假设函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ba071cf7d575d4d4f40415a17faec779)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e98ed73d445693ce2bd0b01cc57f0d57)
是凸函数,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/0dfbda92d4b8824b871c446e958ea908)
是仿射函数(即由一阶多项式构成的函数,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b37eb08d86b6749f5792f496308aaad8)
),A是矩阵,b是向量);并且假设不等式约束
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6f6fc9e025cda4a9e9854f08f7fcf828)
是严格可行的,即存在
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e179a0309aeee08c7eec6e4a84891d89)
,对所有有
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7463fa13a18aec28e74a903cd7091ed9)
,则存在
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d3b671219ed8b11db1d36332b6a2c831)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c3fe25592b1e279f2ddafcfc52d41770)
,分别是原始问题和对偶问题的最优解的充分必要条件是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/a020d552da7cdb87743dbee7d8d4b03e)
和
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/5c6f942c44f081cb6b48106ba4e6e83d)
,满足下面的Karush-Kuhn-Tucker(KKT)条件:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/64ca6a1282f947c7b386dc85acb32d3a)
关于KKT 条件的理解:前面三个条件是由解析函数的知识,对于各个变量的偏导数为0(这就解释了一开始为什么假设三个函数连续可微,如果不连续可微的话,这里的偏导数存不存在就不能保证),后面四个条件就是原始问题的约束条件以及拉格朗日乘子需要满足的约束。
特别的条件
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d037319966a621bb729e11ae2709714a)
叫做KKT的对偶互补条件,这个条件隐含了如果
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ee6224a94990b5867b605eaa94b5fee0)
,那么
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f32f1400733efdfe945d8dbfbc4f0d96)
,也就是说,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c059460159eb2627021e6b06b3c54ecc)
,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/26179ba08056654531c860b49f282bda)
处于可行域的边界上,这时才是起作用的约束,其他位于可行域内部(如
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b60a7113d2cf9ce7f19408a87a49d807)
)的点都是不起作用的约束,这时候的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e16aa54a1c6ae12aa087402fdf0fe2ef)
。
总结:在某些条件下,把原始的约束问题通过拉格朗日函数转化为无约束问题,如果原始问题求解棘手,在满足KKT的条件下用求解对偶问题来代替求解原始问题,使得问题求解更加容易。
这一章节我们就开始介绍从二次优化问题构造拉格朗日函数开始一步步介绍如何运用拉格朗日对偶性求解对偶问题的解,从而得到原问题解的过程。也就是我们的第三个问题。
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d3e69100d06e3c29aabc67f994d9eb4e)
因为我们是要求关于w的最优化,所以在这一章节中我们将约束条件改为关于w的函数:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/31b3f50304c10f4f796a674b240f392f)
为什么将
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d8a3a88f801996150989e7ce92d7dbb1)
而不是令
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/63a6d6a8c108d3c9a58a23e6a469fcb3)
呢?
因为我们为了通过拉格朗日对偶性求解问题,则原问题的约束条件就需要写成前面提到定义一样的形式即
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/5cf9bf819baa08329525910dcfd80371)
(这里的x就是w),也就是约束条件转化为小于0的形式即:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b8e09ae74c7b91c08fe0437478093f36)
0,所以令
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d1b4f8fa24b3659993a76b3cff3c1f99)
。
对于任一训练样本我们只有这样的一个约束条件,注意前面章节最后提到的从KKT对偶互补条件,我们有
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7640507217caffc0dbc6b28d69ee1241)
,但这只是对于函数间隔正好为1的训练样本(例如,那个对应的约束,即保持等式
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/a11af935523c9b3e75188d23d6269810)
)。考虑下图,在下图中实线表示最大间隔分离超平面:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/bb5b15909996d54864c78a7157d7b5c8)
如上图我们可以看到那些有着最小间隔的点正是距离决策边界最近的点,图中有三个这样的点,其中一个在负例两个为正例,他们恰好在决策边界两边的虚线上。这些在虚线上的点就是函数间隔为1的训练样本,这些样本点前面的系数就是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/d2fadadd509dc09892c5c2f3e65bff1b)
,由前面分析知道,这些样本是非零(
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/bc05d34350185b6d929e75502c67ebfb)
> 0)的,
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e5a379d8aaa335f6d165e5c61980dce1)
为这些特殊样本点前面系数,其他的的都是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f3e1540f601a9dae9d101aa10f3d6849)
=0的。这些特殊的点就是支持向量。事实上这些支持向量的个数要比训练集大小要更小就更有帮助。
下面为我们的优化问题构造拉格朗日运算,在这之前先回顾广义的拉格朗日函数:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b462966148ba91427f7bb2a6b365b980)
对比广义的拉格朗日函数,优化问题
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/dff73a856096a6eac1079bcd23393dce)
也就是上式的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3b8fae970e84daebd0c547dd76bbc7d5)
,约束
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f7fe24b57b699be7d778b7a08ace58cc)
1, 参考原问题中的约束条件
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/5ca0ddf64504811ff2eaa1b394da38d3)
,所以没有拉格朗日乘子
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b5751b7c7be29c26d5722d3a46cb3505)
,于是我们为优化问题构造优化问题拉格朗日函数:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6050ba29b9793468727a43172f80b38f)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/81bce801711ccf6087eb90bcce26400e)
对偶问题则是先固定拉格朗日乘子
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/4d904899a96215101734fa15135ed370)
,优化出最优的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/3287a20854075223a10897874ca94b3a)
,最后确定参数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ec0d1ee128227f28abd4cef03bd9641d)
。
在这里就是首先最小化关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1ad255ad799a1ba8e80a569e01a1a156)
的函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c5390977710621e229ea11779574af57)
(就是
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/67a064f5d95f0119ca87dd264a404a6c)
),先固定拉格朗日乘子
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e7d4d7ccd646c92645857fc0e1c98578)
,优化出最优的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2b7c5aeea03d6101e8d645a8c9c6d71d)
,最后再确定参数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c6438b88e3403543fefee9ee00d1958e)
;为了得到
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/19857df60bb97229e408e89792ac5000)
首先需要对关于w的函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ce859cde94fb2eb69715594632751faf)
求偏导,
ecc0
也就是:
上式就是一个关于w的表达式,但是它是最优的,下面对关于b的函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/38477c702be66c922f4321f97dc09d60)
求偏导,
我们将对w求得到的偏导
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b36594c00943e7ede31bc745fda9a095)
带入到原
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/16d67681868fc6ae7509f7d71a9c9aff)
中可得到该函数的最小值:
上式的计算过程如下,其中
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/a66a9c89ecc4070c214958b0fa0ed5da)
,另外5)到6)步用到了线性代数的转置运算,6)到7)步用到了乘法运算法则:
(a+b+c…)(a+b+c…) = aa + ab+ac+ba+bb+bc+ca+cb+cc…
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/62fdac377784709b1f43afbf0d8c1d70)
由关于对b的函数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f9945791bf78322e026551f21a32e2e4)
求偏导计算结果(3)可知,(4)中的最后一项为0;所以简写(4)可得:
回顾得到上式(5)的整个过程,我们是通过最小化关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6fa0e7754083e426bca8b5c0a73b19f3)
的函数得到的,观察5)我们可以发现
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/82b087e3743118337db13f76c4393ba4)
只包含了变量
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b16ff0d1c37be0d7ffffa61f0e69cd0b)
,至此我们完成了对偶问题中先固定乘子
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f2bdc6de18421f3ce71350d9da255d83)
,得到最优化的
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ebb6325cc87f2225193ae28151112443)
(关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e1228c3a040a89a5602e893a2205ffc8)
的表达式)的步骤,然后就是要确定乘子
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f600d06d285b8337cb6e0445adc4bb93)
(有了
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/adbd80377a4b6dd04d1159e45661baf3)
我们才可以最终确定
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/354d2731cdf2b93d77b24811c0134611)
),为了确定
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b56aa20944a2757503eba72f6e3f92bb)
我们下一步就是要最大化
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/bd106ef3c5c966dee9e2f34fa327f536)
,也就是对偶问题:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1bbf4fccf41b0a5b8d81a49ff18d4565)
为了确定
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/6950317cf717c9668f70bdb848010fbf)
,我们首先要将上式表示成关于
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c1b70b62ad5aba730a715fee38c8366e)
的函数即:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/4263ca5a584a1e8e31ce5415df2950de)
其中
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/9ab41de02b6f5c17d33e2d8b5863a741)
为
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/bbd89c74e46bfb2ba9e816fcd481273b)
的内积形式。
到此我们还不能解(6)方程,后面会通过SMO算法来求解,因为在线性不可分模式下寻找最优超平面,还需要引入软间隔,求解的结果和上式类似。但是到这里可以确定的是,一旦确定
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/7f72d2a84e54d9c82fc8a4ac4ef68c2b)
,我们就可以通过式(2),也就是对w求的偏导数:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/e89713efe29c279f431fb956d02a11b7)
求得到
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/23cee1c2b1285340668eb3431837d30d)
,也就是原问题的解。然后通过以下公式,可以直接求出截距
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c0721400ad34a22b76bc1553e443860c)
:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/8cfc2b26b35934d591d79a7715f88c05)
需要我们预测,于是我们回到了预测问题
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1db2559cba75d2fa17099de9a2458394)
,带入:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/8c0968d9f873a0eab94cd226a0097b58)
可得:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/b70ec22618cb49950b2a1431538cf40e)
观察上式可知,为了预测新样本的分类,我们就必须计算一个量,这个量取决于新样本
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/454dbea6a361f451e83589899aa095ab)
和所有训练集中的样本
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/f39aef17338569009694e53e8327f3d3)
的内积和,这个计算不会很大,因为我们从KKT条件可以知道只有支持向量的点
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/297846e4c85f68e6552a17bc64b027da)
,因为我们已经知道支持向量是那些距离最优超平面最近的点,所以这些点不会很多,也就是说大多数的向量点都的系数
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2e54fd3251d4b99297f69de571f80f0e)
;从而上式中的大多数项都等于0,我们只需要计算支持向量和新样本
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/2fc0a637f1c1ef9e0dc0f3b7343102e2)
即可,所以训练完成后最终的模型只和支持向量有关。
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/85b66af5f609443a782d6ed9be640518)
从上图我们可以看到,在二维空间正例和负例是交叉的,但是在三维空间我们就可以找到一个决策曲面将训练样本分隔开来。所以我们希望将在二维空间线性不可分的问题转化到三维去解决,面对现实中更复杂的问题,我们可以抽象的说,将在低维空间线性不可的问题转化为高维空间线性可分的问题,尝试在高维空间去找到这个将正例和负例分隔开来的决策曲面,这样往往比较有效,但是不是绝对的,需要记住这点。
为了将低维的数据(其实也就是向量)映射到高维空间,我们就需要映射函数的表示,我们这里将它统一的表示为:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/5c17fe1f44e75dfb3d42472b5dc3e0a0)
向量的维度也就是说向量的长度,例如幼儿做儿童保健的时候需要看一些指标来判定儿童的生长状况{身长,体重,脑颅宽度,囟门}等,这里我们说指标数据是四维的。
一个房子要评估它的价格有几个特征可以参考如{面积,房间个数,厕所个数}等,这里的特征数据就是三维的。
输入属性(input attributes):就是原始问题的属性,例如面积
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/c8eec3db92c6d2b60f8a61a06f3f54ab)
。
输入特征(input features):就是通过映射后传给学习算法的量。
特征映射(features mapping):从输入属性到输入特征的映射,这里用
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/1af6c30134ed74d8e05ed33323db492b)
表示,输入特征即
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/fa4af1cc61b4ba5c19136e2150bcbbb5)
特别的如果输入向量有m维,则
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/76ba240fb2caaa6e8a18413a319bd203)
可以表示为:
![](https://oscdn.geek-share.com/Uploads/Images/Content/201703/ffa80e2a62013e196db04ffe99ff673d)
接下篇:SVM-支持向量机原理详解与实践之3
SVM原理分析
以下内容接上篇。拉格朗日对偶性(Largrange duality)深入分析
前面提到了支持向量机的凸优化问题中拉格朗日对偶性的重要性。因为通过应用拉格朗日对偶性我们可以寻找到最优超平面的二次最优化,
所以以下可以将寻找最优超平面二次最优化(原问题),总结为以下几个步骤:
在原始权重空间的带约束的优化问题。(注意带约束)
对优化问题建立拉格朗日函数
推导出机器的最优化条件
最后就是在对偶空间解决带拉格朗日乘子的优化问题。
注:以上这个四个步骤是对优化问题的的概括,后面会注意讲解这几个步骤。
于是首先想到的几个随之而来的几个问题:
第一个问题是拉格朗日对偶性是什么?
第二问题是为什么拉格朗日对偶性可以帮助我们找到最优超平面的二次最优化?
第三个问题是如何运用拉格朗日对偶性找到最优超平面的二次最优化?
下面的内容将对以上三个问题进行深入的分析。
首先对于第一个问题,我们首先必须清楚两个概念即原问题和对偶问题,以及他们之间的关系.
原问题
假设是定义在
上的连续可微函数,考虑约束最优化问题:
称为约束最优化问题的原问题。注意必须是连续可微的。类似的对比我们之前分析的最优超平面的二次最优化问题:
其中
就为
,约束条件
对应的就是
,都是带约束的最优化问题。如果是不带约束(没有后面的约束条件)我们知道可以直接对
直接求偏导,即可解出最优解。
但是如何把带约束的原始问题转化为不带约束的原问题呢?拉格朗日函数就是解决这个问题的,于是我们引入广义的拉格朗日函数:
其中
是拉格朗日乘子,需要注意的是约束条件
。
如果我们把上面这个广义的拉格朗日函数
看做是一个关于
的函数,于是要求求解这个关于
的函数
的极大值,表示如下:
要求解上式,我们可以将
看做常数,求解出一对
使得
得极大值,求出这一对
后,又由于
已经确定,很显然的:
只是一个和
有关的函数,我们将这个函数定义为:
这里
中的P下标表示"primal"。让我们假设
已经给定,我们可以通过是否满足约束条件来分析这个函数。
情况一:
违反了原始的约束,也就是
或是
,如下:
有前面的定义可知
,又由于违反了原始的约束,也就是
或是
这个情况,所以很容易通过取拉格朗日乘子
的值使得
,也就是:
情况二:
满足原始的约束,也就是
或是
,所以:
注意要想使得
最大化,由于满足约束条件
或是
,其实就是后面两个式子就等于0,又由于在最大化的过程中
为常数,常数的最大值就是本身,所以:
通过上述的分析我们可以总结
,也就是:
上面分析了原问题
在
满足原始的约束和不满足原始约束的情况下的取值,那么如果是在满足原始约束的条件下面我们考虑最小化
的问题:
也即:
是的,到这里我们发现
和我们前面定义的原问题
一样。它们是等价的,于是我们将原始问题的最优值定义为:
总结:通过拉格朗日函数重新定义一个无约束问题,这个无约束问题等价于原来的约束优化问题,从而将约束问题无约束化!
对偶问题
定义一个关于的函数:
这里的D是指'Dual' 即对偶,注意和
是一个关于
的函数不同,这里的
是一个关于
两个拉格朗日乘子的函数。等式的右边确定是关于
的函数的最小化,当
确定以后,最小值只和
有关。
下面极大化
,于是有:
观察上式,对比原问题:
我们可以看到对偶问题是先最小化
再对结果取最大化,而原问题则相反,它们的区别在于:
原问题先固定
中的
,优化出参数
,再优化出最优的
;
对偶问题则是先固定
,优化出最优的
,最后确定参数
。
为了方便讲解我们定义对偶问题的最优值为:
原问题与对偶问题的关系
定理:若原始问题与对偶问题都有最优值,则:证明:对任意
有:
即:
,
由于原始问题和对偶问题都有最优值,所以:
即:
也就是说原始问题的最优值不小于对偶问题的最优值,但是我们要通过对偶问题来求解原始问题,就必须使得原始问题的最优值与对偶问题的最优值相等,于是可以得出下面的推论:
推论:设
和
分别是原始问题和对偶问题的可行解,如果
,那么
和
分别是原始问题和对偶问题的最优解。
到此我们通过对原问题和对偶问题,以及它们之间关系的了解,也就回答了前面提的第一个问题:拉格朗日对偶性是什么?
这里再次总结拉格朗日对偶性:即
如果原问题有最优解,对偶问题也有最优解,并且相应的最优值是相同的;
KKT条件
定理:对于原始问题和对偶问题,假设函数和
是凸函数,
是仿射函数(即由一阶多项式构成的函数,
),A是矩阵,b是向量);并且假设不等式约束
是严格可行的,即存在
,对所有
有
,则存在
和
,使得
是原始问题的最优解,
是对偶问题的最优解,并且:
定理:对于原始问题和对偶问题,假设函数
和
是凸函数,
是仿射函数(即由一阶多项式构成的函数,
),A是矩阵,b是向量);并且假设不等式约束
是严格可行的,即存在
,对所有有
,则存在
和
,分别是原始问题和对偶问题的最优解的充分必要条件是
和
,满足下面的Karush-Kuhn-Tucker(KKT)条件:
关于KKT 条件的理解:前面三个条件是由解析函数的知识,对于各个变量的偏导数为0(这就解释了一开始为什么假设三个函数连续可微,如果不连续可微的话,这里的偏导数存不存在就不能保证),后面四个条件就是原始问题的约束条件以及拉格朗日乘子需要满足的约束。
特别的条件
叫做KKT的对偶互补条件,这个条件隐含了如果
,那么
,也就是说,
,
处于可行域的边界上,这时才是起作用的约束,其他位于可行域内部(如
)的点都是不起作用的约束,这时候的
。
总结:在某些条件下,把原始的约束问题通过拉格朗日函数转化为无约束问题,如果原始问题求解棘手,在满足KKT的条件下用求解对偶问题来代替求解原始问题,使得问题求解更加容易。
最优间隔分类器
上个章节中我们详细介绍了拉格朗日对偶性,原问题以及对偶问题,还有他们之间的关系,最后还介绍了KKT条件,这也就回答了在拉格朗日对偶性章节开头提到第一个和第二个问题。这一章节我们就开始介绍从二次优化问题构造拉格朗日函数开始一步步介绍如何运用拉格朗日对偶性求解对偶问题的解,从而得到原问题解的过程。也就是我们的第三个问题。
支持向量、构造拉格朗日函数
在二次最优化章节中,我们将寻找决策曲面使得几何间隔最大化的问题转化为了可以通过拉格朗日对偶性求得最优解的二次最优化问题,如下:因为我们是要求关于w的最优化,所以在这一章节中我们将约束条件改为关于w的函数:
为什么将
而不是令
呢?
因为我们为了通过拉格朗日对偶性求解问题,则原问题的约束条件就需要写成前面提到定义一样的形式即
(这里的x就是w),也就是约束条件转化为小于0的形式即:
0,所以令
。
对于任一训练样本我们只有这样的一个约束条件,注意前面章节最后提到的从KKT对偶互补条件,我们有
,但这只是对于函数间隔正好为1的训练样本(例如,那个对应的约束,即保持等式
)。考虑下图,在下图中实线表示最大间隔分离超平面:
如上图我们可以看到那些有着最小间隔的点正是距离决策边界最近的点,图中有三个这样的点,其中一个在负例两个为正例,他们恰好在决策边界两边的虚线上。这些在虚线上的点就是函数间隔为1的训练样本,这些样本点前面的系数就是
,由前面分析知道,这些样本是非零(
> 0)的,
为这些特殊样本点前面系数,其他的的都是
=0的。这些特殊的点就是支持向量。事实上这些支持向量的个数要比训练集大小要更小就更有帮助。
下面为我们的优化问题构造拉格朗日运算,在这之前先回顾广义的拉格朗日函数:
对比广义的拉格朗日函数,优化问题
也就是上式的
,约束
1, 参考原问题中的约束条件
,所以没有拉格朗日乘子
,于是我们为优化问题构造优化问题拉格朗日函数:
求解拉格朗日函数
根据上一章节所描述的,求解上式我们需要从它的对偶形式着手,所以首先要找到上式的对偶形式,为了达到这个目的,参考上一章节对偶问题的描述:对偶问题则是先固定拉格朗日乘子
,优化出最优的
,最后确定参数
。
在这里就是首先最小化关于
的函数
(就是
),先固定拉格朗日乘子
,优化出最优的
,最后再确定参数
;为了得到
首先需要对关于w的函数
求偏导,
(3.7.2-1) |
求偏导,
(3.7.2-2) |
带入到原
中可得到该函数的最小值:
(3.7.2-3) |
,另外5)到6)步用到了线性代数的转置运算,6)到7)步用到了乘法运算法则:
(a+b+c…)(a+b+c…) = aa + ab+ac+ba+bb+bc+ca+cb+cc…
由关于对b的函数
求偏导计算结果(3)可知,(4)中的最后一项为0;所以简写(4)可得:
(3.7.2-4) |
的函数得到的,观察5)我们可以发现
只包含了变量
,至此我们完成了对偶问题中先固定乘子
,得到最优化的
(关于
的表达式)的步骤,然后就是要确定乘子
(有了
我们才可以最终确定
),为了确定
我们下一步就是要最大化
,也就是对偶问题:
为了确定
,我们首先要将上式表示成关于
的函数即:
其中
为
的内积形式。
到此我们还不能解(6)方程,后面会通过SMO算法来求解,因为在线性不可分模式下寻找最优超平面,还需要引入软间隔,求解的结果和上式类似。但是到这里可以确定的是,一旦确定
,我们就可以通过式(2),也就是对w求的偏导数:
求得到
,也就是原问题的解。然后通过以下公式,可以直接求出截距
:
(3.7.2-6) |
预测新样本分类
假设我们已经通过SMO算法计算出了w,随之计算出了b,于是我们得到了一个可供预测新样本分类的模型,现在来了一个新的样本需要我们预测,于是我们回到了预测问题
,带入:
可得:
观察上式可知,为了预测新样本的分类,我们就必须计算一个量,这个量取决于新样本
和所有训练集中的样本
的内积和,这个计算不会很大,因为我们从KKT条件可以知道只有支持向量的点
,因为我们已经知道支持向量是那些距离最优超平面最近的点,所以这些点不会很多,也就是说大多数的向量点都的系数
;从而上式中的大多数项都等于0,我们只需要计算支持向量和新样本
即可,所以训练完成后最终的模型只和支持向量有关。
不可分模式下的最优超平面
前面我们已经讨论了线性可分模式下的最优超平面的情况,但是在现实中训练集往往是线性不可分的。例如下图所示:从上图我们可以看到,在二维空间正例和负例是交叉的,但是在三维空间我们就可以找到一个决策曲面将训练样本分隔开来。所以我们希望将在二维空间线性不可分的问题转化到三维去解决,面对现实中更复杂的问题,我们可以抽象的说,将在低维空间线性不可的问题转化为高维空间线性可分的问题,尝试在高维空间去找到这个将正例和负例分隔开来的决策曲面,这样往往比较有效,但是不是绝对的,需要记住这点。
为了将低维的数据(其实也就是向量)映射到高维空间,我们就需要映射函数的表示,我们这里将它统一的表示为:
向量的维度也就是说向量的长度,例如幼儿做儿童保健的时候需要看一些指标来判定儿童的生长状况{身长,体重,脑颅宽度,囟门}等,这里我们说指标数据是四维的。
一个房子要评估它的价格有几个特征可以参考如{面积,房间个数,厕所个数}等,这里的特征数据就是三维的。
输入属性(input attributes):就是原始问题的属性,例如面积
。
输入特征(input features):就是通过映射后传给学习算法的量。
特征映射(features mapping):从输入属性到输入特征的映射,这里用
表示,输入特征即
特别的如果输入向量有m维,则
可以表示为:
接下篇:SVM-支持向量机原理详解与实践之3
相关文章推荐
- SVM-支持向量机原理详解与实践
- SVM-支持向量机原理详解与实践之一
- SVM(support vector machine)支持向量机原理详解
- SVM -支持向量机原理与实践之实践篇
- 支持向量机原理与实践(二):scikit-learn中SVM的使用
- 支持向量机(SVM)原理与实践(一)
- 支持向量机SVM原理详解+白板推导
- 支持向量机 (SVM)分类器原理分析与基本应用
- 负载均衡原理与实践详解 第五篇 负载均衡时数据包流程详解
- 负载均衡原理与实践详解 第六篇 健康检查机制详解(上)
- ML学习心得(4)----SVM支持向量机 之二
- 机器学习算法与Python实践之(四)支持向量机(SVM)实现
- 机器学习算法与Python实践之(四)支持向量机(SVM)实现
- SVM-支持向量机详解(四)--多类分类器
- 机器学习算法与Python实践之(四)支持向量机(SVM)实现(源码)
- 支持向量机SVM原理
- 机器学习算法与Python实践之(二)支持向量机(SVM)初级
- 负载均衡原理与实践详解
- 机器学习算法与Python实践之(三)支持向量机(SVM)进阶
- 负载均衡原理与实践详解 第十六篇 负载均衡网络设计 把负载均衡当作二层交换机还是三层路由器