黑马程序员技术交流社区

标题: 【上海校区】感知机模型 [打印本页]

作者: 梦缠绕的时候    时间: 2018-8-28 09:27
标题: 【上海校区】感知机模型
感知机模型1. 模型概览

方法:感知机模型
适用问题:二分类
模型特点:分离超平面
模型类型:判别模型
学习策略:极小化误分点到超平面距离
损失函数:误分点到超平面距离
学习算法:随机梯度下降法

2. 模型介绍

感知机(perceptron)是处理二分类的线性分类模型。感知机旨在求出将训练数据进行线性划分的分离超平面,属于判别模型,所以,导入误分类的损失函数,利用梯度下降法极小化损失函数,求得感知机模型,感知机预测是用学习得到的感知机模型对新输入的数据进行分类。感知机在1957年由Rosenblatt提出,是神经网络和支持向量机的基础。

3. 模型定义

由输入空间到输出空间的如下函数:


f(x)=sign(w⋅x+b)f(x)=sign(w⋅x+b)


称为感知机。其中w为权重,b为偏置,sign为符号函数:


sign(x)={+1,x≥0−1,x<0sign(x)={+1,x≥0−1,x<0


所以,感知机输出是{+1,-1}.

几何解释:
线性方程


wx+b=0wx+b=0


对应特征空间的一个超平面S,其中w为该平面的法向量,b为超平面的截距。这个超平面将特征空间分为两个部分,位于两部分的点分别被分为正负两类,因此,超平面S被称为分离超平面。如下图所示:

4. 感知机学习策略

首先解释一下什么是线性可分:对包含正负样例点的集合T,如果存在一个超平面S能够将所有正负样例点完全分在平面两侧,则称T为线性可分的,否则为线性不可分。感知机模型就是假设训练集合为线性可分的。

接下来我们定义损失函数,并将其最小化。感知机模型的损失函数为所有误分类点到超平面的距离和,这很好理解。不选择误分类点的个数是因为,它不是w,b的连续可导函数,不好优化。损失函数形式如下:


L(w,b)=−∑xi∈Myi(w⋅xi+b)L(w,b)=−∑xi∈Myi(w⋅xi+b)


我们来推导一下:
空间任意点<span class="MathJax" id="MathJax-Element-5-Frame" tabindex="0" data-mathml="x0" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">x0x0 到超平面S的距离为:


1∥w∥|w⋅x0+b|1‖w‖|w⋅x0+b|


这里<span class="MathJax" id="MathJax-Element-7-Frame" tabindex="0" data-mathml="‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">∥w∥‖w‖为w的二范数。
其次,对于误分类的数据<span class="MathJax" id="MathJax-Element-8-Frame" tabindex="0" data-mathml="(xi,yi)" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">(xi,yi)(xi,yi)来说


−yi(w⋅xi+b)>0−yi(w⋅xi+b)>0


因为|yi|=1|yi|=1,对于误分点数据(xi,yi)(xi,yi)有:

|w⋅xi+b|=|yi(w⋅xi+b)|=−yi(w⋅xi+b)|w⋅xi+b|=|yi(w⋅xi+b)|=−yi(w⋅xi+b)


所以误分类点到超平面距离可以表示为:

−1∥w∥yi(w⋅xi+b)−1‖w‖yi(w⋅xi+b)


假设误分类点集合为M,那么所有误分类点到超平面S的距离和为


−1∥w∥∑xi∈Myi(w⋅xi+b)−1‖w‖∑xi∈Myi(w⋅xi+b)


不考虑1∥w∥1‖w‖,就得到感知机模型的损失函数:

L(w,b)=−∑xi∈Myi(w⋅xi+b)L(w,b)=−∑xi∈Myi(w⋅xi+b)


为什么不考虑<span class="MathJax" id="MathJax-Element-17-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; font-weight: normal; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖?
网上有人说<span class="MathJax" id="MathJax-Element-18-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖是个定值,但是个人觉得平面不唯一,这个值肯定也会变。通过参考他人观点结合思考,觉得原因可以列为以下两点,如果有更好见解的朋友欢迎讨论!

1、<span class="MathJax" id="MathJax-Element-19-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖不影响<span class="MathJax" id="MathJax-Element-20-Frame" tabindex="0" data-mathml="yi(w⋅xi+b)" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">yi(w⋅xi+b)yi(w⋅xi+b)正负的判断,即不影响学习算法的中间过程。因为感知机学习算法是误分类驱动的,这里需要注意的是所谓的“误分类驱动”指的是我们只需要判断<span class="MathJax" id="MathJax-Element-21-Frame" tabindex="0" data-mathml="−yi(w⋅xi+b)" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">−yi(w⋅xi+b)−yi(w⋅xi+b)的正负来判断分类的正确与否,而<span class="MathJax" id="MathJax-Element-22-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖并不影响正负值的判断。所以<span class="MathJax" id="MathJax-Element-23-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖对感知机学习算法的中间过程可以不考虑;

2、<span class="MathJax" id="MathJax-Element-24-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖不影响感知机学习算法的最终结果。因为感知机学习算法最终的终止条件是所有的输入都被正确分类,即不存在误分类的点。则此时损失函数为0. 对应于<span class="MathJax" id="MathJax-Element-25-Frame" tabindex="0" data-mathml="−1‖w‖∑xi∈Myi(w⋅xi+b)" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">−1∥w∥∑xi∈Myi(w⋅xi+b)−1‖w‖∑xi∈Myi(w⋅xi+b),即分子为0.则可以看出<span class="MathJax" id="MathJax-Element-26-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖对最终结果也无影响。

综上所述,即使忽略<span class="MathJax" id="MathJax-Element-27-Frame" tabindex="0" data-mathml="1‖w‖" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">1∥w∥1‖w‖,也不会对感知机学习算法的执行过程产生任何影响。反而还能简化运算,提高算法执行效率。

5. 感知机模型的学习算法

感知机学习算法是对上述损失函数进行极小化,求得w和b,采用的方法为随机梯度下降法。目标函数如下:



minL(w,b)=−∑xi∈Myi(w⋅xi+b)minL(w,b)=−∑xi∈Myi(w⋅xi+b)


首先任取一个超平面(w0,b0)(w0,b0),然后用梯度下降法不断极小化目标函数,过程中不是一次使M中所有误分类点的梯度下降,而是随机选取一个误分类点使其梯度下降。
假设误分类点集合M是固定的,那么损失函数L(w,b)L(w,b)的梯度由


∇wL(w,b)=−∑xi∈Myixi∇wL(w,b)=−∑xi∈Myixi



∇bL(w,b)=−∑xi∈Myi∇bL(w,b)=−∑xi∈Myi


给出(求偏导)。
更新公式如下:


w←w+ηyixiw←w+ηyixi



b←b+ηyib←b+ηyi


其中<span class="MathJax" id="MathJax-Element-35-Frame" tabindex="0" data-mathml="η" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">ηη(0<<span class="MathJax" id="MathJax-Element-36-Frame" tabindex="0" data-mathml="η" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">ηη<=1)为步长,也称为学习率。这样通过迭代可以期待损失函数不断减小,直到为0. 注意,感知机。算法由于采用不用的处置或选取不同的误分类点时,解可以不同。

6. 证明算法收敛性

现在证明,对于现行可分数据集感知机学习算法收敛,即经过有限次迭代可以得到一个将训练数据集完全正确划分的分离超平面及感知机模型。

为了便于叙述和推导,将偏置b并入权重向量w,记作<span class="MathJax" id="MathJax-Element-37-Frame" tabindex="0" data-mathml="w^=(wT,b)T" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">w^=(wT,b)Tw^=(wT,b)T,同时将输入向量加以扩充,加入常数1,记作<span class="MathJax" id="MathJax-Element-38-Frame" tabindex="0" data-mathml="x^=(xT,1)T" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">x^=(xT,1)Tx^=(xT,1)T。 这样<span class="MathJax" id="MathJax-Element-39-Frame" tabindex="0" data-mathml="x^∈Rn+1,w^∈Rn+1" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">x^∈Rn+1,w^∈Rn+1x^∈Rn+1,w^∈Rn+1,则<span class="MathJax" id="MathJax-Element-40-Frame" tabindex="0" data-mathml="w^⋅x^=w⋅x+b" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">w^⋅x^=w⋅x+bw^⋅x^=w⋅x+b。

通过证明Novikoff定理证明感知机算法的收敛性

假设训练数据集T是线性可分的。<span class="MathJax" id="MathJax-Element-41-Frame" tabindex="0" data-mathml="T={(x1,y1),(x2,y2),⋯,(xN,yN)}" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">T={(x1,y1),(x2,y2),⋯,(xN,yN)}T={(x1,y1),(x2,y2),⋯,(xN,yN)} 其中<span class="MathJax" id="MathJax-Element-42-Frame" tabindex="0" data-mathml="xi∈Rn" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">xi∈Rnxi∈Rn . <span class="MathJax" id="MathJax-Element-43-Frame" tabindex="0" data-mathml="yi={+1,−1}" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">yi={+1,−1}yi={+1,−1}.<span class="MathJax" id="MathJax-Element-44-Frame" tabindex="0" data-mathml="i=1,2,⋯,N" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">i=1,2,⋯,Ni=1,2,⋯,N .

(1) 存在<span class="MathJax" id="MathJax-Element-45-Frame" tabindex="0" data-mathml="‖w^opt‖=1" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">∥w^opt∥=1‖w^opt‖=1 的超平面<span class="MathJax" id="MathJax-Element-46-Frame" tabindex="0" data-mathml="w^opt⋅x^=wopt⋅x+bopt=0" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">w^opt⋅x^=wopt⋅x+bopt=0w^opt⋅x^=wopt⋅x+bopt=0将训练数据集完全分开,且存在<span class="MathJax" id="MathJax-Element-47-Frame" tabindex="0" data-mathml="r&gt;0" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">r>0r>0,对所有<span class="MathJax" id="MathJax-Element-48-Frame" tabindex="0" data-mathml="i=1,2,⋯,N" role="presentation" style="box-sizing: border-box; outline: 0px; display: inline; line-height: normal; font-size: 16px; text-align: left; word-spacing: normal; word-wrap: normal; white-space: nowrap; float: none; direction: ltr; max-width: none; max-height: none; min-width: 0px; min-height: 0px; border: 0px; word-break: break-all; position: relative;">i=1,2,⋯,Ni=1,2,⋯,N。


yi(w^opt⋅x^i)=yi(wopt⋅xi+bopt)≥ryi(w^opt⋅x^i)=yi(wopt⋅xi+bopt)≥r


(2) 令R=max∥x^i∥.R=max‖x^i‖.则在训练集上感知机算法的误分类次数kk满足

k≤(Rr)2k≤(Rr)2


证明过程如下:



作者: 不二晨    时间: 2018-8-30 17:09
奈斯,加油加油




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2