深度学习中的归一化(normalization)和正则化(regularization)

机器学习的学习过程基于概率和统计学,学习到的知识能用于其它数据的一个基本假设是独立同分布(IID),因此把数据变成同分布是很有必要的。


A.权重归一化: WN

不归一化特征,而是归一化权重。

B.特征归一化: BNLNINGNSN

归一化操作

BN、LN、IN、GN这一系列方法的作用可以表示为:\hat{x}_{i}=\frac{1}{\sigma }_{i}\left ( x_{i}-\mu _{i} \right )(1),其中x是某层中的特征,i是一个索引。对2维图像来说,i=\left ( i_{N},i_{C},i_{H},i_{W} \right )是一个按\left ( N,C,H,W \right )顺序索引特征的4维向量,其中N是batch轴,C是通道轴,HW是高度和宽度轴。

\mu\sigma是均值和标准差,计算方式是:\mu _{i} = \frac{1}{m} \sum_{k\in S_{i}}^{ } x_{k}\sigma _{i} = \sqrt{ \frac{1}{m} \sum_{k\in S_{i}}^{ } \left ( x_{k} - \mu _{i} \right ) ^{2} + \epsilon },其中\epsilon是一个值较小的常量,S_{i}是用于计算均值和标准差的像素集合,m是集合的大小。

实现区别

四种特征归一化实现方法的区别在于S_{i}不同。

图1.归一化方法。蓝色的像素被归一化为相同的均值和方差。
  1. BN中S_{i}=\left \{ k\mid k_{C}=i_{C} \right \}C坐标相同的像素在一块归一化。
  2. LN中S_{i} = \left \{ k \mid k_{N}=i_{N} \right \}N坐标相同的像素在一块归一化。
  3. IN中S_{i}=\left \{ k\mid k_{N}=i_{N},k_{C}=i_{C} \right \}N坐标和C坐标都相同的像素在一块归一化。
  4. GN中S_{i} = \left \{ k\mid k_{N}=i_{N},\left \lfloor \frac{k_{C}}{C/G} \right \rfloor = \left \lfloor \frac{i_{C}}{C/G} \right \rfloor\right \}N坐标相同的像素分为G组,组内的像素在一块归一化。组数G是一个预定义的超参数。\frac{C}{G}是每组的通道数。\left \lfloor \cdot \right \rfloor代表向下取整。图1最右的图中C=6G=2k_{C}\left \{ 0,1,2,3,4,5 \right \}中取值时\left \lfloor \frac{k_{C}}{C/G} \right \rfloor的值为\left \{ 0,0,0,1,1,1 \right \}i_{C}同理,因此把N坐标相同的像素分为2(G)组,每组的通道数是3(C/G)。

如公式(1),BN、LN、IN学习各通道的线性变换以补偿表征能力的可能损失:y_{i}=\gamma \hat{x}_{i}+\beta,其中\gamma\beta是可训练的尺度和偏移。

作用区别

图2.设置batch size为32/CPU时的误差曲线比较。模型是ResNet-50,数据集是ImageNet。左图是训练误差,右图是验证误差。

BN

BN是唯一依赖batch size的归一化方法,在batch size较小时误差急剧增大。由于内存限制,检测、分割、视频识别这类任务的batch size一般都较小,所以BN就不合适。

图2.ImageNet分类误差和batch size大小。图示的模型是ResNet-50,用8个GPU在ImageNet训练集上训练,在验证集上评估。BN的误差随batch size减小而急剧增大,GN的误差和batch size变化无关。当batch size为2时,GN的误差比BN小10%。

GN

GN是LN和IN的复合,性能优于LN和IN。如图2,GN对batch size不敏感,因此可以用于batch size较小的情况。

SN

虽然LN、IN对batch size不敏感,但其归一化能力较弱,当batch size较大时不如BN。因此SN组合LN、IN、BN,让网络学习权重参数以自动选择归一化方法:batch size越小,SN中BN的权重系数越小,IN和LN的权重系数越大;batch size越大,SN中BN的权重系数越大,IN和LN的权重系数越小。


猜你喜欢

转载自blog.csdn.net/qq_26697045/article/details/85050756