Kaggle知识点:训练神经网络的7个技巧

发表时间:2024-03-24 17:48

本文将了解在训练神经网络模型时如何充分利用反向传播算法的技巧和诀窍。


神经网络模型使用随机梯度下降进行训练,模型权重使用反向传播算法进行更新。通过训练神经网络模型解决的优化问题非常具有挑战性,尽管这些算法在实践中表现出色,但不能保证它们会及时收敛到一个良好的模型。


1训练神经网络的挑战在训练数据集的新示例之间取得平衡。

2七个具体的技巧,可帮助您更快地训练出更好的神经网络模型。


学习和泛化

使用反向传播设计和训练网络需要做出许多看似任意的选择,例如节点的数量和类型、层的数量、学习率、训练和测试集等。这些选择可能至关重要,但却没有百分之百可靠的决策法则,因为它们在很大程度上取决于问题和数据。训练神经网络模型的目标最具挑战性,因为它要解决两个难题:


1学习训练数据集以最小化损失。

2泛化模型性能以便在未见过的示例上进行预测。


在这些问题之间存在权衡,因为学得太好的模型泛化能力可能较差,而泛化良好的模型可能欠拟合。训练神经网络的目标是在这两方面找到一个良好的平衡。


在拟合神经网络模型时,这些术语可以定义为:


1偏差:衡量网络输出在所有数据集上的平均差异与期望函数的差异。

2方差:衡量网络输出在数据集之间变化的程度。


这种表述将模型的容量定义为偏差的选择,控制可以学习的函数范围。它将方差视为训练过程的函数,并在过拟合训练数据集和泛化误差之间取得平衡


1在训练初期,偏差较大,因为网络输出与期望函数相差很远。方差非常小,因为数据尚未产生太大的影响。在训练后期,偏差较小,因为网络已经学到了基本函数。

2然而,如果训练时间太长,网络还将学到特定数据集的噪声,这称为过度训练。在这种情况下,方差将很大,因为噪声在数据集之间变化。


技巧1:随机梯度下降与批量学习

随机梯度下降,也称为在线梯度下降,是指从训练数据集中随机选择一个示例,估算误差梯度,然后更新模型参数(权重)的算法版本。它的效果是快速训练模型,尽管可能会导致模型权重的大幅、嘈杂的更新。


通常情况下,基本反向传播首选随机学习,原因有三:


1随机学习通常比批量学习快得多。

2随机学习通常会导致更好的解决方案。

3随机学习可用于跟踪变化。


批量梯度下降涉及使用训练数据集中所有示例的平均值来估算误差梯度。它执行更快,从理论上更容易理解,但导致学习速度较慢。


尽管随机学习具有诸多优势,仍有理由考虑使用批量学习:


1收敛条件是众所周知的。

2许多加速技术(例如共轭梯度)仅在批量学习中操作。

3对权重动态和收敛速率的理论分析更简单。


尽管批量更新具有优势,但在处理非常大的数据集时,随机学习仍然通常是首选方法,因为它更简单更快。


技巧2:打乱样本顺序

神经网络从最意外的样本中学得最快。因此,建议在每次迭代中选择对系统最不熟悉的样本。实现这个技巧的一个简单方法是确保用于更新模型参数的连续示例来自不同的类别。


这个技巧也可以通过向模型展示并重新展示它在进行预测时犯的最多错误或产生最多错误的示例来实现。这种方法可能是有效的,但如果在训练期间过度表示的示例是离群值,它也可能导致灾难。


选择信息内容最大的示例:


1打乱训练集,使连续的训练示例永远(很少)不属于同一类别。

2更频繁地呈现产生大误差的输入示例,而不是产生小误差的示例。


技巧3:标准化输入

当训练数据集中的示例总和为零时,神经网络通常学得更快。这可以通过从每个输入变量中减去平均值(称为居中)来实现。通常,如果训练集上每个输入变量的平均值接近零,收敛速度会更快。


此外将输入居中也会提高模型对来自先前层的输入到隐藏层的收敛性。这是令人着迷的,因为它为后来近15年发展并广泛流行的批量归一化技术奠定了基础。


因此,最好将输入移动,以使训练集的平均值接近零。这个启发式方法应该应用于所有层,这意味着我们希望节点的输出的平均值接近零,因为这些输出是下一层的输入。


1训练集上每个输入变量的平均值应接近零。

2缩放输入变量,使它们的协方差大致相同。

3如果可能的话,输入变量应该无关联。


技巧4Sigmoid 激活函数

非线性激活函数赋予神经网络非线性能力。其中一种最常见的激活函数形式是 Sigmoid


在隐藏层使用 logistic tanh 激活函数不再是一个合理的默认选择,因为使用 ReLU 的性能模型收敛速度更快。


技巧5:选择目标值

在二元分类问题的情况下,目标变量可能是 logistic 激活函数的渐近值集合 {0, 1},或者是双曲正切函数的渐近值集合 {-1, 1},分别对应使用交叉熵或铰链损失函数,即使在现代神经网络中也是如此。


在激活函数的饱和点(边缘)取得值可能需要更大的权重,这可能使模型变得不稳定。


技巧6:初始化权重

权重的初始值对训练过程有很大影响。权重应该随机选择,但以 sigmoid 函数的线性区域为主要激活区域。这个建议也适用于 ReLU 的权重激活,其中函数的线性部分是正的。


初始权重对模型学习有重要影响,其中大权重使激活函数饱和,导致不稳定的学习,而小权重导致梯度非常小,进而学习缓慢。理想情况下,我们寻求模型权重位于激活函数的线性(非曲线)部分之上。


技巧7:选择学习率

学习率是模型权重在算法的每次迭代中更新的量。较小的学习率可能导致收敛较慢,但可能得到更好的结果,而较大的学习率可能导致更快的收敛,但可能得到不太理想的结果。


建议当权重值开始来回变化,例如振荡时,减小学习率。


1大多数方案在权重向量振荡时减小学习率,并在权重向量遵循相对稳定方向时增加学习率。

2显然,为网络中的每个权重选择不同的学习率(eta)可以提高收敛性。[…] 主要思想是确保网络中的所有权重大致以相同的速度收敛。


分享到: