深度学习实践(项目经验)
研究方向
数学/深度学习的核心/梯度下降法
-
参数优化的一种策略,用于寻找局部最小值
-
微积分中使用梯度表示函数增长最快的方向;相应的,神经网络中使用负梯度来指示损失函数下降最快的方向
-
梯度实际上是损失函数对网络中每个参数的偏导所组成的向量,其中计算各偏导的方法即反向传播算法
-
从另一个角度来理解方向这个概念,可以认为负梯度中的每一项实际传达了两个信息:
- 基本的梯度下降法要求每次使用所有训练样本的平均损失来更新参数
- 为了加快计算效率,一般的做法会首先打乱所有训练样本,每次计算梯度时会随机抽取其中一批(Batch)来计算平均损失——这就是“随机梯度下降”。
也有地方将使用全部、一个、一批样本的方法分别称为“批量梯度下降”、“随机梯度下降”、“小批量梯度下降”
《深度学习》 8.1.3 批量算法和小批量算法
- 较大的批能得到更精确的梯度估计,但回报是小于线性的。
- 较小的批能带来更好的泛化误差,泛化误差通常在批大小为 1 时最好。但是,因为梯度估计的高方差,小批量训练需要较小的学习率以保持稳定性,这意味着更长的训练时间。
原因可能是由于小批量在学习过程中带来了噪声,使产生了一些正则化效果 (Wilson and Martinez, 2003)
- 内存消耗和批的大小成正比,当批量处理中的所有样本可以并行处理时。
- 在某些硬件上使用特定大小可以减少运行时间。尤其是在使用 GPU 时,通常使用 2 的幂数作为批量大小可以获得更少的运行时间。一般,2 的幂数的取值范围是 32 到 256,16 有时在尝试大模型时使用。
-
反向传播概述:
梯度下降法中需要利用损失函数对所有参数的梯度来寻找局部最小值点;
而反向传播算法就是用于计算该梯度的具体方法,其本质是利用链式法则对每个参数求偏导。
数学/深度学习的核心/反向传播的 4 个基本公式
-
可以用 4 个公式总结反向传播的过程
标量形式:
上标
(l)
表示网络的层,(L)
表示输出层(最后一层);下标j
和k
指示神经元的位置;w_jk
表示l
层的第j
个神经元与(l-1)
层第k
个神经元连线上的权重 -
符号说明,其中:
-
以 均方误差(MSE) 损失函数为例,有
-
Nielsen 的课程中提供了另一种更利于计算的表述,本质上是一样的。
-
使用激活函数的目的是为了向网络中加入非线性因素;
从而加强网络的表示能力,解决线性模型无法解决的问题
为什么加入非线性因素能够加强网络的表示能力?——神经网络的万能近似定理
-
神经网络的万能近似定理认为主要神经网络具有至少一个非线性隐藏层,那么只要给予网络足够数量的隐藏单元,它就可以以任意的精度来近似任何从一个有限维空间到另一个有限维空间的函数。
-
如果不使用非线性激活函数,那么每一层输出都是上层输入的线性组合;
此时无论网络有多少层,其整体也将是线性的,这会导致失去万能近似的性质
《深度学习》 6.4.1 万能近似性质和深度;
-
但仅部分层是纯线性是可以接受的,这有助于减少网络中的参数。
《深度学习》 6.3.3 其他隐藏单元
《深度学习》 6.3 隐藏单元
-
ReLU
及其扩展都基于以下公式:当
α=0
时,即标准的线性整流单元 -
绝对值整流(absolute value rectification)
固定
α = -1
,此时整流函数即绝对值函数g(z)=|z|
-
渗漏整流线性单元(Leaky ReLU, Maas et al., 2013)
固定
α
为一个小值,比如 0.01 -
参数化整流线性单元(parametric ReLU, PReLU, He et al., 2015)
将
α
作为一个可学习的参数 -
maxout
单元 (Goodfellow et al., 2013a)maxout
单元 进一步扩展了ReLU
,它是一个可学习的k
段函数Keras 简单实现
# input shape: [n, input_dim] # output shape: [n, output_dim] W = init(shape=[k, input_dim, output_dim]) b = zeros(shape=[k, output_dim]) output = K.max(K.dot(x, W) + b, axis=1)
参数数量是普通全连接层的 k 倍
深度学习(二十三)Maxout网络学习 - CSDN博客
很多未发布的非线性激活函数也能表现的很好,但没有比流行的激活函数表现的更好。比如使用
cos
也能在 MNIST 任务上得到小于 1% 的误差。通常新的隐藏单元类型只有在被明确证明能够提供显著改进时才会被发布。
-
线性激活函数:
如果神经网络的每一层都由线性变换组成,那么网络作为一个整体也将是线性的,这会导致失去万能近似的性质。但是,仅部分层是纯线性是可以接受的,这可以帮助减少网络中的参数。
-
softmax:
softmax 单元常作为网络的输出层,它很自然地表示了具有 k 个可能值的离散型随机变量的概率分布。
-
径向基函数(radial basis function, RBF):
在神经网络中很少使用 RBF 作为激活函数,因为它对大部分 x 都饱和到 0,所以很难优化。
-
softplus:
softplus
是ReLU
的平滑版本。通常不鼓励使用 softplus 函数,大家可能希望它具有优于整流线性单元的性质,但根据经验来看,它并没有。
(Glorot et al., 2011a) 比较了这两者,发现 ReLU 的结果更好。
-
硬双曲正切函数(hard tanh):
它的形状和 tanh 以及整流线性单元类似,但是不同于后者,它是有界的。
- 避免梯度消失***
sigmoid
函数在输入取绝对值非常大的正值或负值时会出现饱和现象——在图像上表现为变得很平,此时函数会对输入的微小变化不敏感——从而造成梯度消失;ReLU
的导数始终是一个常数——负半区为 0,正半区为 1——所以不会发生梯度消失现象
- 减缓过拟合**
ReLU
在负半区的输出为 0。一旦神经元的激活值进入负半区,那么该激活值就不会产生梯度/不会被训练,造成了网络的稀疏性——稀疏激活- 这有助于减少参数的相互依赖,缓解过拟合问题的发生
- 加速计算*
ReLU
的求导不涉及浮点运算,所以速度更快
为什么 ReLU 不是全程可微/可导也能用于基于梯度的学习?
- 虽然从数学的角度看 ReLU 在 0 点不可导,因为它的左导数和右导数不相等;
- 但是在实现时通常会返回左导数或右导数的其中一个,而不是报告一个导数不存在的错误。从而避免了这个问题
《深度学习》 7.1.1 L2 参数正则化 & 7.1.2 - L1 参数正则化
机器学习中正则化项L1和L2的直观理解 - CSDN博客
相同点
- 限制模型的学习能力——通过限制参数的规模,使模型偏好于权值较小的目标函数,防止过拟合。
不同点
- L1 正则化可以产生更稀疏的权值矩阵,可以用于特征选择,同时一定程度上防止过拟合;L2 正则化主要用于防止模型过拟合
- L1 正则化适用于特征之间有关联的情况;L2 正则化适用于特征之间没有关联的情况。
- L1 & L2 正则化会使模型偏好于更小的权值。
- 更小的权值意味着更低的模型复杂度;添加 L1 & L2 正则化相当于为模型添加了某种先验,限制了参数的分布,从而降低了模型的复杂度。
- 模型的复杂度降低,意味着模型对于噪声与异常点的抗干扰性的能力增强,从而提高模型的泛化能力。——直观来说,就是对训练数据的拟合刚刚好,不会过分拟合训练数据(比如异常点,噪声)——奥卡姆剃刀原理
-
对目标函数添加范数正则化,训练时相当于在范数的约束下求目标函数
J
的最小值 -
带有L1 范数(左)和L2 范数(右)约束的二维图示
- 图中
J
与L1
首次相交的点即是最优解。L1
在和每个坐标轴相交的地方都会有“顶点”出现,多维的情况下,这些顶点会更多;在顶点的位置就会产生稀疏的解。而J
与这些“顶点”相交的机会远大于其他点,因此L1
正则化会产生稀疏的解。 L2
不会产生“顶点”,因此J
与L2
相交的点具有稀疏性的概率就会变得非常小。
- 图中
《深度学习》 7.12 Dropout
-
集成方法的主要想法是分别训练不同的模型,然后让所有模型表决最终的输出。
集成方法奏效的原因是不同的模型通常不会在测试集上产生相同的误差。
集成模型能至少与它的任一成员表现得一样好。如果成员的误差是独立的,集成将显著提升模型的性能。
-
Bagging 是一种集成策略——具体来说,Bagging 涉及构造 k 个不同的数据集。
每个数据集从原始数据集中重复采样构成,和原始数据集具有相同数量的样例——这意味着,每个数据集以高概率缺少一些来自原始数据集的例子,还包含若干重复的例子
更具体的,如果采样所得的训练集与原始数据集大小相同,那所得数据集中大概有原始数据集
2/3
的实例
集成方法与神经网络:
-
神经网络能找到足够多的不同的解,意味着他们可以从模型平均中受益——即使所有模型都在同一数据集上训练。
神经网络中随机初始化的差异、批训练数据的随机选择、超参数的差异等非确定性实现往往足以使得集成中的不同成员具有部分独立的误差。
-
简单来说,Dropout 通过参数共享提供了一种廉价的 Bagging 集成近似—— Dropout 策略相当于集成了包括所有从基础网络除去部分单元后形成的子网络。
-
通常,隐藏层的采样概率为
0.5
,输入的采样概率为0.8
;超参数也可以采样,但其采样概率一般为1
权重比例推断规则
- 权重比例推断规则的目的是确保在测试时一个单元的期望总输入与在训练时该单元的期望总输入大致相同。
- 实践时,如果使用
0.5
的采样概率,权重比例规则相当于在训练结束后将权重除 2,然后像平常一样使用模型;等价的,另一种方法是在训练期间将单元的状态乘 2。
- 在 Bagging 的情况下,所有模型都是独立的;而在 Dropout 的情况下,所有模型共享参数,其中每个模型继承父神经网络参数的不同子集。
- 在 Bagging 的情况下,每一个模型都会在其相应训练集上训练到收敛。而在 Dropout 的情况下,通常大部分模型都没有显式地被训练;取而代之的是,在单个步骤中我们训练一小部分的子网络,参数共享会使得剩余的子网络也能有好的参数设定。
- 一般使用服从的高斯分布(
mean=0, stddev=1
)或均匀分布的随机值作为权重的初始化参数;使用0
作为偏置的初始化参数 - 一些启发式方法会根据输入与输出的单元数来决定初始值的范围
- 其他初始化方法
- 随机正交矩阵(Orthogonal)
- 截断高斯分布(Truncated normal distribution)
Keras 提供的所有参数初始化方法:Keras/Initializers
- CNN更像视觉,天然具有二维整体性;而LSTM更像听觉和语音,总是通过串行的方式来理解整体。
首次超越LSTM : Facebook 门卷积网络新模型能否取代递归模型? - 深度学习-炼数成金-Dataguru专业数据分析社区