本文介绍多层感知机,会先按照历史顺序介绍多层感知机诞生前的一些模型,后面介绍具体实现与其算法。
一、前戏
1.1 阈值逻辑单元(Threshold Logic Unit, TLU)
文章图片
如上图是一个神经元,我们可以看到它的胞体、轴突、树突。
我们高中的时候学过一种东西叫做神经递质,分为抑制性神经递质和兴奋性神经递质,以及一些关于兴奋和抑制相关的知识;
我们把这些递质看作神经元的输入,则可模仿神经元建立以下模型(M-P unit):
文章图片
【人工智能|AI遮天传 DL-多层感知机】其中:
那个方块中的符号代表阶跃函数解释如下:
文章图片
文章图片
兴奋性输入
文章图片
抑制性输入
文章图片
二元化输出- 输入与输出都是二进制的
文章图片
阈值
- M-P单元可以被单个抑制性信号所抑制,就像真实的神经元一样。
- 如果
文章图片
,
文章图片
, . . . ,
文章图片
至少有一个为 1, 则该单元被抑制且 = 0 - 否则将计算总激活值
文章图片
并与阈值 相比较 (如果 = 0 则 = 0)- 如果 ≥ 则发放值为1,表示兴奋。
- 如果 < 结果为0,表示非兴奋。
我们还可以用该模型实现布尔函数:
比如一组数据 0 0 1 0,合取为0,析取为1,我们只需分别把阈值设置为4和1即可:
文章图片
这样加和做非线性处理后与阈值进行比较即可得到想要的答案。
当然 若是想实现取反操作,则可以加上抑制性输入或使用非门。
文章图片
单调逻辑函数
单调逻辑函数: 指的是对于给定的两组n元逻辑变量 = (1, … , ) 和 = (1, … , ), 当输入 中的1是输入 的子集时,满足 ≥ ().上面定义看不懂没关系,这里举个例子:x=(0,1,1,0), y=(0,0,1,0);则x构成集合{
文章图片
,
文章图片
}, y构成集合{
文章图片
}集合2里只有1个1,集合1里有两个,集合2是集合1的子集,那就是单调的。
命题1:不受限制的McCulloch–Pitts(M-P)单元只能实现单调逻辑函数。
即我们前面学的 and 和 or 都是单调逻辑函数, 而 not nor等需要引入抑制,不是单调逻辑函数。
文章图片
结构性综合(Constructive Synthesis)
每个具有n元变量的逻辑函数都可以被写成列表形式。
- 假设有K行的结果是1:
- 用一个M-P单元来表示结果是1的n元变量
- 用析取操作来连接K个M-P单元
文章图片
比如我们自己定义一个逻辑函数:只有输入为(0,0,1) (0,1,0) 时输出结果为1,其它都为0。
则对每一组数据的x1,x2,x3执行右侧操作:
- 第一行专门为(0,0,1)设置,第二行专门为(0,1,0)设置。
- 对于一组数据,如果是(0,0,1)或者(0,1,0)其中一个,即经过第一行和第二行计算输出结果为1和0,经过一二行析取(析取的阈值肯定是1,前面的阈值要看我们自己怎么定义),得到结果为1。
- 如果输入不在这两种情况里面,则第一层的一二行返回都是0,析取为0。
- 如果x1为1,则该单元被抑制,直接输出y=0。
文章图片
→ {0, 1} 都能由一个两层的M-P网络计算得到。
注:这里两层指的是左右两层,第一层上下可以是多行。
什么是构造所有逻辑函数的基本单元?
我们前面所学,抑制性连接可以被非门代替;
对于一个输入:(0,0,1)为1,其它为0:
文章图片
则此时x1,x2是抑制性连接,可以写成非的形式。
- 左侧x1,x2,x3求和为1,且此时抑制单元x1,x2都为0,输出1(析取),否则0.
- 右侧如果x1为0输出1,x2为0输出1,与x3求和为3,与阈值3比较,输出1(合取),否则0.
命题3:所有的逻辑函数都能被包含与、或、非功能的网络所实现。
命题1:不受限制的McCulloch–Pitts(M-P)单元只能实现单调逻辑函数。
命题2:任何逻辑函数 ∶
文章图片
→ {0, 1} 都能由一个两层的M-P网络计算得到。
1.2 感知机 (Perceptron) 之前我们输入的都是逻辑单元01,这次x可以为实数,对x进行加权(w),求和,与阈值(b)进行比较,同样大于的取1,不大于的取0或者-1。
这个比较操作通过移项可以写成公式
文章图片
,w和x为行或列数为1的矩阵,相乘结果为实数。
文章图片
在M-P单元的输入连接上加上权重注:该更新参数的过程类似于梯度下降,不过对于t和y它们是离散的,但在有限距离内依旧可以收敛但正确解上:
提出监督学习:
其中为学习率且 > 0
- 对于每个数据点
文章图片
及对应的标签
文章图片
, 计算输出
文章图片
- 更新参数:
文章图片
;
文章图片
- 决策表边界是一个超平面
文章图片
文章图片
命题 4: 如果训练数据集线性可分,则感知机必定能收敛。并且训练中需要迭代的次数存在一个上限。证明参见 (Novikoff, 1962)
命题1:不受限制的McCulloch–Pitts(M-P)单元只能实现单调逻辑函数。
命题2:任何逻辑函数 ∶
文章图片
→ {0, 1} 都能由一个两层的M-P网络计算得到。
命题3:所有的逻辑函数都能被包含与、或、非功能的网络所实现。
文章图片
缺点: 决策边界通常与样本点距离很近, 因此对噪声敏感。
对于图右侧,无法寻找一个线性超平面将其分解,这也使得神经网络进入第一次低潮。
同一层内的多个感知机
当多个感知机被组合起来时, 输出神经元之间是互相独立的; 因此多个感知机的学习过程可以看成是相互独立的。
文章图片
1.3 自适应线性神经网络(ADALINE)和MADALINE模型 结构与感知机一致,训练算法不同。
文章图片
用另一视角:
文章图片
而不是用来更新参数
为学习率且 > 0
- 最小化均方误差
文章图片
.- 学习算法:
文章图片
,
文章图片
- 决策表边界是一个超平面
文章图片
或
文章图片
别名: LMS规则,Delta规则,Widrow-Hoff 规则,实际上是SGD。
文章图片
- 对变量 的线性激活函数 (这也是名字中(Adaptive Linear Neuron)线性的由来)
- 阶跃函数只作用于输出 并且输出不参与学习过程
MADALINE模型
- MADALINE: 多个ADALINE模型。
- 用于分类的三层(输入层, 隐含层, 输出层)全连接前馈网络,将 ADALINE作为其隐含层和输出层单元。
- 三种不同的MADALINE训练算法:
- 最早追溯到1962年并且不能用于更新隐含层和输出层的连接权重。
- 1988年提出了改进训练算法。
- 第三个算法应用于改进后的网络,将阶跃函数替换成 sigmoid激活函数; 后来被证明与反向传播等价。
二、多层感知机 2.1 回顾:感知机:
文章图片
自适应线性神经网络(ADALINE)
文章图片
用ADALINE解决异或(XOR)问题:
布尔函数:
文章图片 |
文章图片 |
t |
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
文章图片
其中
文章图片
令 = 0, = 0, 则这样的话无论输入什么,输出都成了定值0.5,显然是错的。
则求得:
文章图片
文章图片
文章图片
文章图片
文章图片
在二维平面上显然无法有一条直线将0和1分开。
局限:
- 感知机和ADALINE都只能解决线性可分的分类问题
- 这个问题导致了神经网络领域的研究在1960-1970年代退 潮 (第一次寒冬)
- 如果所研究的问题是线性不可分的,我们该怎么做?
这个问题主要是由于它是一个单层模型,这个时候我们就要用到多层感知机,对输入进行一个非线性的转换,转换到另外的一个空间,我们称作特征空间,经过多次转换有可能在一个特征空间就可以用一个超平面把这几个点给分开了。
此外在SVM领域核函数向量机(Kernel SVM)专门用来解决这种情况。
2.2 多层感知机(Multi-layer Perceptron, MLP) 以下是一个多层感知机的结构, 每个计算单元我们用圆圈来表示。
对于输入来讲x就是问题的一种表示,对于图像来讲的话那么x就是一个像素点(一个实数来表示灰度、一个三维向量表示RGB值),对于声音来讲的话x为每刻声音的强度,对于自然语言的话x表示每个单词...
其他层都要做计算,包括输出层,像之前所介绍的Softmax输出一个y值,与标签t进行比较。中间还有很多层,叫做隐藏层。
隐藏层的目的就是要对输入进行多次的非线性变换,期望经过多次的变换,输出能够用一个很简单的模型,比如线性回归的模型就能把类别分开。
文章图片
除了输入共 层前向传播
连接类型:
每个神经元接收前一层神经元的输出,并根据激活函数作出响应。
- 相邻层之间的神经元两两连接(多层感知机又叫全连接模型)
- 相邻层之间没有反馈连接(单项箭头)
- 同一层内没有横向连接
文章图片
- 遍历 = 1, … , ? 1。
- 计算第 层的神经元 的输入
文章图片
及其输出
文章图片
。 -
文章图片
表示l层单元 j 与l-1层单元 i 之间的权重,
文章图片
表示整个l -1 层与 l 层 单元 j 的偏置。 - 是激活函数,注意
文章图片
即第一层输入。 - = 即最后一层对应分类层,比如回归。
- 前l-1层全部数据的加权求和再加上一个偏置得到u。
- 对z进行y=f(z)激活得来。
向量形式的前向计算
文章图片
激活函数
Logistic函数及其梯度
文章图片
文章图片
双曲正切函数及其梯度
文章图片
文章图片
整流线性激活函数(ReLU)及其梯度
文章图片
文章图片
文章图片
再看异或(XOR)问题
布尔函数:
文章图片 |
文章图片 |
t |
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
文章图片
我们在输入层与输出层之间加入了一个隐藏层,权值为V,偏置为c。
则经过这一层,分别对于上表4种情况的h为:
文章图片
ps:
文章图片
取ReLU结果为:
文章图片
文章图片
此时就变得线性可分了。
继续计算得到y,分别为0,1,1,0与 t 一 一对应,相同。
这样XOR问题就可以被正确求解,但该问题比较简单,我们可以通过试一试的办法把权值和偏置试出来,但对于一个实际问题,维数很高,我们就需要让机器去学习这些算法。
2.3 反向计算 我们在反向计算中就会使用BP算法来学习这些参数。
我们回顾多层感知机,其倒数第二层会把问题引入到如分类问题上去,
损失函数:输出层的激活函数和损失函数由任务类型决定,见下表。它们与隐藏层的激活函数的选择是独立的。
文章图片
其中
文章图片
是每个样本n的损失函数
文章图片
以上y分别使用了 logistic/sigmoid 函数和 softmax 函数
- 如果是均方误差或欧氏距离,可以使用ReLU其它的如双曲正切。
- 而使用交叉熵函数作为损失函数,不能用ReLU。
文章图片
参数更新
参数更新(α为学习率)
文章图片
文章图片
正则化(在损失函数加上额外的一项,叫做权重衰减,减轻过拟合。)
文章图片
参数衰减通常作用于
文章图片
(对
文章图片
不必要,只有w与x相乘)
的参数更新变为:
文章图片
梯度、局部敏感度
定义局部敏感度:
文章图片
对于
文章图片
:
文章图片
文章图片
其中
文章图片
f 是激活函数。
即我们求误差函数对所有参数的偏导,等价去于计算各层的局部敏感度。
局部敏感度求法
从最后一层出发,最后一层损失函数可能是 MSE 或者 Softmax交叉熵层。
- 均方误差(MSE)层的局部敏感度
文章图片
- Softmax交叉熵层的局部敏感度
文章图片
- 其它层的局部敏感度
文章图片
向量形式的反向传播
文章图片
梯度消失(Gradient Vanishing)
对于隐含层 1 ≤ < :
文章图片
- 对于logistic函数
文章图片
则
文章图片
- 对于tanh函数
文章图片
则
文章图片
对于这两个激活函数, 从第层到第一层, () 变得越来越小。 浅层的梯度会逐渐接近于零。
文章图片
ReLU可以缓解这一问题
实现过程
前向计算 – 计算
文章图片
和
文章图片
, 对所有的 = 1,2, … ,
后向计算 – 计算
文章图片
和
文章图片
对所有的 = , ? 1, … ,1
对所有 = 1,2, … , , 更新
文章图片
和
文章图片
模块化编程
- 用类来实现层,并提供前向和后向计算函数。
- 不同类型的层拥有不同的前向和后向计算函数,例如输入层、隐含层、softmax输出层、sigmoid输出层等。
- 通过组合不同的模块来构造不同的多层感知机模型。
实验
实验1:对二维平面上的点进行分类
A Neural Network Playground (tensorflow.org)
文章图片
文章图片
实验2: 手写体数字识别
ConvNetJS MNIST demo (stanford.edu)
文章图片
2.4 层分解 输入层或隐含层
文章图片
可以被解构为两层平方损失函数层
- 全连接层:
文章图片
- 激活层:
文章图片
文章图片
可以被解构为两层交叉熵损失层
平方损失函数需要哪些层来实现?
- 激活层:
文章图片
f 可以是任意函数- 损失层:
文章图片
FC layer + activation layer + Euclidean loss layer (全连接 + 激活 + 欧式距离损失)
文章图片
可以被解构为两层例子1
平方损失函数需要哪些层来实现?
- Softmax层:
文章图片
f 是Softmax函数- 损失层:
文章图片
不过并不必要
FC layer + softmax cross-entropy layer (全连接 + softmax交叉熵损失)
带隐含层的多层感知机,使用平方误差损失。
文章图片
例子2
文章图片
练习
文章图片
参考答案
文章图片
向量形式的反向传播
文章图片
2.5 训练技巧 初始化参数
可以从某个分布中采样:
- 高斯分布(Gaussian)
- 均值为零,标准差固定(例如0.01)的高斯分布
- Xavier
- 均值为零,标准差固定为 1/ in 的一种分布, 其中 in 是当前神经元输入的个数
- 通常使用高斯分布或均匀分布
- MSRA
- 均值为零,标准差固定为 2/ in 的高斯分布
学习率
随机梯度下降中的学习率 通常远小于批量梯度下降中的,因为更新过程中存在更大的方差。
选择合适的策略
- 一个标准的做法是选择一个足够小的学习率使得网络开始稳定收敛, 在收敛速度变慢后将学习率减半。
- 另一种更好的策略是每一轮训练后都在一组留出数据集(held out set) 上评估模型,如果相邻两轮训练中目标函数的改变量小于某个阈值, 则减小学习率。
- 另一种常用策略是在第t次迭代(iteration)中将学习率修改为 /+ ,其中a是初始的学习率,b控制学习率何时开始衰减。
训练样本的顺序
如果样本的训练顺序固定,梯度的计算可能会有偏差,并导致收敛情况变差。
通常在每轮训练前都要随机打乱(random shuffle)数据集。
病态的曲率(Pathological Curvature)
目标函数的形式通常是狭长且浅的沟壑,就像 Rosenbrock 函数一样。
在深度网络中,目标函数的局部最优点经常以这种形式呈现, 所以标准的随机梯度下降算法。通常会在“沟壑”两侧反复震荡。
文章图片
文章图片
动量(Momentum)
动量(Momentum)是一种迫使目标函数沿着“沟壑”快速下降的方法。
动量的更新过程:
文章图片
- 是当前的速度向量。
- ∈ (0,1] 决定了之前迭代的梯度以多大程度参与到当前的更新中。
- 一种策略: 设为 0.5 直到收敛开始稳定,然后增大到0.9或更大。
文章图片
三、总结
- 多层感知机
- 前向计算
- 后向计算: 反向传播
- 层分解
- 全连接层, sigmoid层, ReLU层, 损失函数层
- 训练技巧-1
- 参数初始化, 学习率, 训练样本顺序, 动量
推荐阅读
- 人工智能|【IJCAI 2022】参数高效的大模型稀疏训练方法,大幅减少稀疏训练所需资源
- 数据库|实时计算,连接时序数据库和核心业务
- 科技|12大专场,48个议题,AISummit全球人工智能技术大会火热报名中
- 大数据|基于神策用户画像,在线教育企业线索标签体系搭建及培育全流程解析
- 大数据那些事儿|神策军丨优秀 Leader 养成记(多做简单又有效的事)
- spinning|强化学习入门项目spinning up(1)安装
- 大数据|字节跳动重磅发布 2022 年 6 大前端技术发展趋势
- 数据分析师|【机器学习算法】神经网络和深度学习-4 重要的BP网络使用总结,了解BP神经网络的魅力
- 人工智能|2022年最受欢迎的几本人工智能书