xavier 初始化

Xavier 初始化 (也称 Glorot 初始化 )是由 Xavier Glorot 和 Yoshua Bengio 在 2010 年的论文《Understanding the Difficulty of Training Deep Feedforward Neural Networks》中提出的。它是深度学习历史上第一个被广泛认可的、专门解决梯度消失/爆炸问题的权重初始化方法。

1. 为什么需要它?(与 Kaiming 的背景类似)

在深度网络(如 6-10 层)刚兴起时,人们发现网络很难训练。原因在于:

  • 梯度消失:浅层(靠近输入层)的权重几乎不更新,无法学习。
  • 梯度爆炸:梯度变得极大,导致权重更新失控。

Xavier 指出,问题的根源在于权重的初始尺度 。他提出一个核心原则:让每一层输出的方差等于输入的方差,并且让梯度的方差在反向传播时也保持恒定

2. 核心数学原理

Xavier 的推导基于以下假设:

  • 激活函数是线性的(在初始化阶段,tanh 在小值附近近似线性)。
  • 权重和输入是独立同分布的,且均值为 0。
  • 不使用偏置(或偏置初始化为 0)。

推导结果:权重的方差应该设置为:

\\text{Var}(W) = \\frac{2}{\\text{fan_in} + \\text{fan_out}}

  • fan_in:当前层的输入神经元数量(即权重矩阵的输入维度)。
  • fan_out:当前层的输出神经元数量(即权重矩阵的输出维度)。

这个公式同时考虑了前向传播(用到 fan_in)和反向传播(用到 fan_out),是一个调和平均的思想。

3. 常用实现公式

在实际代码中,Xavier 初始化通常采用均匀分布正态分布来采样:

均匀分布 (Uniform)

由于均匀分布的方差为 ( \frac{(b-a)^2}{12} ),为了得到上述方差,边界 ( b ) 和 ( a ) 应设为:

W \\sim U\\left\[-\\sqrt{\\frac{6}{\\text{fan_in} + \\text{fan_out}}},\\ \\sqrt{\\frac{6}{\\text{fan_in} + \\text{fan_out}}}\\right

]

正态分布 (Normal)

W \\sim \\mathcal{N}\\left(0,\\ \\sqrt{\\frac{2}{\\text{fan_in} + \\text{fan_out}}}\\right)

4. 代码实现(PyTorch 示例)

PyTorch 提供了内置的 Xavier 初始化方法:

python 复制代码
import torch.nn as nn

# 定义一个线性层
linear_layer = nn.Linear(256, 128)

# Xavier 均匀分布初始化
nn.init.xavier_uniform_(linear_layer.weight, gain=1.0)

# Xavier 正态分布初始化
nn.init.xavier_normal_(linear_layer.weight, gain=1.0)

# 如果有偏置,通常初始化为 0
if linear_layer.bias is not None:
    nn.init.constant_(linear_layer.bias, 0)

参数说明

  • gain:可选的缩放因子。对于不同的激活函数,建议使用不同的 gain 值(见下表)。

5. 适用场景与激活函数选择

激活函数 推荐初始化 gain 值
Tanh Xavier gain = 1.0(默认)
Sigmoid Xavier gain = 1.0
ReLU ❌ Xavier 效果差,应使用 Kaiming ---
Leaky ReLU Kaiming 更好 ---

为什么 ReLU 不适合 Xavier?

  • Xavier 假设激活函数关于 0 对称,且在小值范围内近似线性。
  • ReLU 将所有负值置为 0,导致输出方差减半。因此 Xavier 初始化在 ReLU 网络中会导致信号逐渐消失。
  • 这就是为什么后来 Kaiming He 专门针对 ReLU 提出了 Kaiming 初始化(方差公式中使用 ( \frac{2}{\text{fan_in}} ) 而不是 ( \frac{2}{\text{fan_in} + \text{fan_out}} ))。

6. Xavier vs. Kaiming 对比

维度 Xavier 初始化 Kaiming 初始化
提出时间 2010 年 2015 年
适用激活函数 Tanh, Sigmoid, 线性 ReLU, Leaky ReLU, PReLU
方差公式 ( \frac{2}{\text{fan_in} + \text{fan_out}} ) ( \frac{2}{\text{fan_in}} ) (ReLU)
理论假设 激活函数关于 0 对称 激活函数非对称(存在负值截断)
解决的主要问题 梯度消失/爆炸(浅层网络) 深层网络(如 ResNet)中的 ReLU 信号衰减

7. 总结与使用建议

  • 激活函数是 Tanh 或 Sigmoid :优先选择 Xavier 初始化
  • 激活函数是 ReLU 或其变体 :优先选择 Kaiming 初始化 (PyTorch 中也称 kaiming_uniform_kaiming_normal_)。
  • 不太确定时:现代深度学习(尤其是 CNN)几乎默认使用 ReLU + Kaiming 初始化。但如果你在使用 Transformer 或 MLP 时遇到 Tanh,Xavier 依然是不错的选择。
  • 一个小技巧 :PyTorch 的 nn.init.calculate_gain() 可以帮助你计算不同激活函数下推荐的 gain 值,用于调整初始化尺度。
python 复制代码
# 计算不同激活函数的推荐 gain
gain_tanh = nn.init.calculate_gain('tanh')   # 输出 1.0
gain_relu = nn.init.calculate_gain('relu')   # 输出 1.414 (即 sqrt(2))
gain_sigmoid = nn.init.calculate_gain('sigmoid')  # 输出 1.0

总的来说,Xavier 初始化是深度学习中对称激活函数(Tanh/Sigmoid)的最佳选择,也是理解现代初始化方法(如 Kaiming)的基础。掌握它,你就掌握了深度学习权重初始化的核心理念。

相关推荐
Lihua奏2 天前
从单核到多核:CPU为什么不能再只靠提频变快
深度学习
拾年2752 天前
大模型的"聪明"从哪来?聊聊 AI 数据集的那些事儿
人工智能·深度学习·机器学习
饼干哥哥6 天前
开源Skills|搭建亚马逊动态关键词库系统,每天抓SSS级机会词
人工智能·深度学习·数据分析
武子康8 天前
调查研究-191 SenseVoice 不只是 ASR:把语音从“转文字“升级成“理解状态“
人工智能·深度学习·openai
武子康9 天前
调查研究-189 Kronos 调研:金融 K 线基础模型,是真突破,还是量化圈的新玩具?
人工智能·深度学习·openai
xiao5kou4chang6kai414 天前
MATLAB机器学习、深度学习--从数据预处理到模型训练
深度学习·机器学习·matlab·数据预处理
renhongxia115 天前
世界模型作为AGI落地底层底座的作用
人工智能·深度学习·生成对抗网络·自然语言处理·知识图谱·agi
计算机科研狗@OUC15 天前
(cvpr26) AIMDepth: Asymmetric Image-Event Mamba for Monocular Depth Estimation
人工智能·深度学习·计算机视觉
β添砖java15 天前
深度学习(22)网络中的网络NiN
人工智能·深度学习
Kobebryant-Manba15 天前
深度学习时候d2l报错和使用问题
人工智能·深度学习