线性整流函数
整流線性單位函数(Rectified Linear Unit, ReLU),又称修正线性单元,是一种人工神经网络中常用的激勵函数(activation function),通常指代以斜坡函数及其变种为代表的非线性函数。
机器学习与 |
---|
比较常用的线性整流函数有斜坡函数 ,以及带泄露整流函数(Leaky ReLU),其中 为神经元(Neuron)的输入。线性整流被认为有一定的生物学原理[1],并且由于在实践中通常有着比其他常用激勵函数(譬如逻辑函数)更好的效果,而被如今的深度神经网络广泛使用于诸如图像识别等计算机视觉人工智能领域[1]。
定义
通常意义下,线性整流函数指代数学中的斜坡函数,即
而在神经网络中,线性整流作为神经元的激活函数,定义了该神经元在线性变换 之后的非线性输出结果。换言之,对于进入神经元的来自上一层神经网络的输入向量 ,使用线性整流激活函数的神经元会输出
至下一层神经元或作为整个神经网络的输出(取决现神经元在网络结构中所处位置)。
变种
线性整流函数在基于斜坡函数的基础上有其他同样被广泛应用于深度学习的变种,譬如带泄露线性整流(Leaky ReLU)[2], 带泄露随机线性整流(Randomized Leaky ReLU)[3],以及噪声线性整流(Noisy ReLU)[4].
带泄露线性整流
在输入值 为负的时候,带泄露线性整流函数(Leaky ReLU)的梯度为一个常数 ,而不是0。在输入值为正的时候,带泄露线性整流函数和普通斜坡函数保持一致。换言之,
在深度学习中,如果设定 为一个可通过反向传播算法(Backpropagation)学习的变量,那么带泄露线性整流又被称为参数线性整流(Parametric ReLU)[5]。
带泄露随机线性整流
带泄露随机线性整流(Randomized Leaky ReLU, RReLU)最早是在Kaggle全美数据科学大赛(NDSB)中被首先提出并使用的。相比于普通带泄露线性整流函数,带泄露随机线性整流在负输入值段的函数梯度 是一个取自连续性均匀分布 概率模型的随机变量,即
其中 且 。
优势
相比于传统的神经网络激活函数,诸如逻辑函数(Logistic sigmoid)和tanh等双曲函数,线性整流函数有着以下几方面的优势:
- 仿生物学原理:相关大脑方面的研究表明生物神經元的訊息编码通常是比较分散及稀疏的[6]。通常情况下,大脑中在同一时间大概只有1%-4%的神经元处于活跃状态。使用線性修正以及正規化(regularization)可以对机器神经网络中神经元的活跃度(即输出为正值)进行调试;相比之下,逻辑函数在输入为0时達到 ,即已经是半饱和的稳定状态,不够符合实际生物学对模拟神经网络的期望[1]。不过需要指出的是,一般情况下,在一个使用修正线性单元(即线性整流)的神经网络中大概有50%的神经元处于激活态[1]。
- 简化计算过程:没有了其他复杂激活函数中诸如指数函数的影响;同时活跃度的分散性使得神经网络整体计算成本下降
参考资料
- Xavier Glorot, Antoine Bordes and Yoshua Bengio. (PDF). AISTATS. 2011 [2016-09-28]. (原始内容 (PDF)存档于2016-12-13).
- Andrew L. Maas, Awni Y. Hannum and Andrew Y. Ng. (PDF). ICML. 2013 [2019-07-29]. (原始内容 (PDF)存档于2021-01-10).
- Xu, Bing; Wang, Naiyan; Chen, Tianqi; Li, Mu. . 2015. arXiv:1505.00853v2 . cite arXiv模板填写了不支持的参数 (帮助)
- Vinod Nair and Geoffrey Hinton. (PDF). ICML. 2010. (原始内容 (PDF)存档于2014-03-24).
- He, Kaiming; Zhang, Xiangyu; Ren, Shaoqing; Sun, Jian. . 2015. arXiv:1502.01852v1 . cite arXiv模板填写了不支持的参数 (帮助)
- David Attwell and Simon B. Laughlin. . JCBFM. 2001 [2016-09-28]. (原始内容存档于2016-09-08).