1 神经网络之超参数
超参数在神经网络的设计和训练中起着至关重要的作用。它们是在开始训练之前设置的参数,与网络的结构、训练过程和优化算法有关。正确的超参数选择对于达到最优模型性能至关重要。
2 神经网络结构的超参数
层数(Layers): 决定了神经网络的深度。每一层包含一组神经元,负责从输入数据中提取特征。层数越多,网络越深,理论上可以学习更复杂的模式,但也可能导致过拟合和计算成本增加。
神经元数量(Neurons): 每层中的神经元数量影响网络的宽度。更多的神经元可以提供更强的学习能力,但同样可能增加过拟合的风险和计算负担。
激活函数(Activation Functions): 决定了神经网络如何处理输入信号和输出信号。不同的激活函数对网络的性能和收敛速度有显著影响。
常用的激活函数为sigmoid、tanh、relu、leaky relu、elu等。采用sigmoid激活函数计算量较大,而且sigmoid饱和区变换缓慢,求导趋近于0,导致梯度消失。sigmoid函数的输出值恒大于0,这会导致模型训练的收敛速度变慢。
tanh它解决了zero-centered的输出问题,然而,gradient vanishing的问题和幂运算的问题仍然存在。
relu从公式上可以看出,解决了gradient vanishing问题并且计算简单更容易优化,但是某些神经元可能永远不会被激活,导致相应的参数永远不能被更新(Dead ReLU Problem);leaky relu有relu的所有优点,外加不会有Dead ReLU问题,但是在实际操作当中,并没有完全证明leaky relu总是好于relu。
elu也是为解决relu存在的问题而提出,elu有relu的基本所有优点,但计算量稍大,并且没有完全证明elu总是好于relu。
特征学习函数:常用的特征学习函数有cnn、rnn、lstm、gru。cnn注重词位置上的特征,而具有时序关系的词采用rnn、lstm、gru抽取特征会更有效。gru是简化版的lstm,具有更少的参数,训练速度更快。但是对于足够的训练数据,为了追求更好的性能可以采用lstm模型。
3 训练过程的超参数
批量大小(Batch Size): 指在更新模型权重时使用的训练样本数。较小的批量大小可以提高模型的泛化能力,但可能导致训练过程不稳定。较大的批量大小加快训练速度,但增加内存需求。
对于小数据量的模型,可以全量训练,这样能更准确的朝着极值所在的方向更新。但是对于大数据,全量训练将会导致内存溢出,因此需要选择一个较小的batch_size。
如果这时选择batch_size为1,则此时为在线学习,每次修正方向为各自样本的梯度方向修正,难以达到收敛。batch_size增大,处理相同数据量的时间减少,但是达到相同精度的轮数增多。实际中可以逐步增大batch_size,随着batch_size增大,模型达到收敛,并且训练时间最为合适。
迭代次数(Epochs): 整个训练数据集被遍历和学习的次数。太少的迭代次数可能导致模型未能充分学习,而太多则可能导致过拟合。
学习率(Learning Rate): 决定了在优化过程中更新模型权重的步长。太高的学习率可能导致训练不收敛,太低则训练过程缓慢。学习速率的设置第一次可以设置大一点的学习率加快收敛,后续慢慢调整;也可以采用动态变化学习速率的方式(比如,每一轮乘以一个衰减系数或者根据损失的变化动态调整学习速率)。
优化器(Optimizer):器学习训练的目的在于更新参数,优化目标函数,常见优化器有SGD,Adagrad,Adadelta,RMSprop,Adam等。其中SGD和Adam优化器是最为常用的两种优化器,SGD根据每个batch的数据计算一次局部的估计,最小化代价函数。
学习速率决定了每次步进的大小,因此我们需要选择一个合适的学习速率进行调优。学习速率太大会导致不收敛,速率太小收敛速度慢。因此SGD通常训练时间更长,但是在好的初始化和学习率调度方案的情况下,结果更可靠。
Adam优化器结合了Adagrad善于处理稀疏梯度和RMSprop善于处理非平稳目标的优点,能够自动调整学习速率,收敛速度更快,在复杂网络中表现更优。
4 正则化和避免过拟合的超参数
正则化项(Regularization): 如L1和L2正则化,用于减少模型的过拟合。通过在损失函数中添加正则化项来惩罚大的权重值。从公式可以看出,加入l1正则化的目的是为了加强权值的稀疏性,让更多值接近于零。而l2正则化则是为了减小每次权重的调整幅度,避免模型训练过程中出现较大抖动。
Dropout率: 在训练过程中随机丢弃神经元的比例,以防止过拟合。数据第一次跑模型的时候可以不加dropout,后期调优的时候dropout用于防止过拟合有比较明显的效果,特别是数据量相对较小的时候。
特征抽取:max-pooling、avg-pooling是深度学习中最常用的特征抽取方式。max-pooling是抽取最大的信息向量,然而当存在多个有用的信息向量时,这样的操作会丢失大量有用的信息。
avg-pooling是对所有信息向量求平均,当仅仅部分向量相关而大部分向量无关时,会导致有用信息向量被噪声淹没。针对这样的情况,在有多个有用向量的情形下尽量在最终的代表向量中保留这些有用的向量信息,又想在只有一个显著相关向量的情形下直接提取该向量做代表向量,避免其被噪声淹没。那么解决方案只有:加权平均,即Attention。
5 其他超参数
权重初始化(Weight Initialization): 决定了网络权重的初始分布。不同的初始化方法可能显著影响模型的收敛速度和最终性能。常见的初始化有随机初始化、均匀分布初始值、正态分布初始值等。
梯度裁剪(Gradient Clipping): 限制梯度的最大值,以防止在训练过程中出现梯度爆炸。
早停(Early Stopping): 一种防止过拟合的技术,当验证集上的性能不再提升时停止训练。模型收敛即可停止迭代,一般可采用验证集作为停止迭代的条件。如果连续几轮模型损失都没有相应减少,则停止迭代。
6 总结
神经网络的超参数调整是一个需要细致考虑的过程。理解每个超参数的作用和如何影响模型的学习过程对于构建高效、准确的神经网络至关重要。超参数的选择不仅取决于数据和任务的性质,还需要考虑计算资源的限制。有效的超参数调整通常需要大量的实验和经验。