09aaa-LayerNorm是什么?

09aaa-LayerNorm是什么?📊

本文档详细解释层归一化(Layer Normalization, LayerNorm)的核心概念,涵盖数学定义、计算步骤、与 BatchNorm 的核心区别,以及 Transformer 选择 LayerNorm 的原因,最后提供 PyTorch 代码示例 🛠️

1. 什么是 LayerNorm?🤔

本章解释 LayerNorm 的基本概念和核心思想

Layer Normalization(层归一化) 是一种对神经网络的每一层输出进行归一化的技术,由 Jimmy Lei Ba、Jamie Ryan Kiros 和 Geoffrey E. Hinton 于 2016 年提出。

它的核心思想非常简单:对单个样本的所有特征维度计算均值和方差,进行 Z-score 标准化,再通过可学习的缩放参数 γ \gamma γ 和偏移参数 β \beta β 恢复表达能力。

直观理解:假设一个 token 的特征向量为 x = [ x 1 , x 2 , ... , x d ] \mathbf{x} = [x_1, x_2, \ldots, x_d] x=[x1,x2,...,xd],LayerNorm 先把这个向量变成均值为 0、方差为 1 的标准形式,然后让网络自己学习怎么缩放( γ \gamma γ)和平移( β \beta β)到最佳位置。

2. 核心公式 📝

本章给出 LayerNorm 的完整数学表达式并拆解每一步

LayerNorm 的计算分为三步:

第1步:计算均值

μ = 1 d ∑ i = 1 d x i \mu = \frac{1}{d} \sum_{i=1}^{d} x_i μ=d1i=1∑dxi

第2步:计算方差

σ 2 = 1 d ∑ i = 1 d ( x i − μ ) 2 \sigma^2 = \frac{1}{d} \sum_{i=1}^{d} (x_i - \mu)^2 σ2=d1i=1∑d(xi−μ)2

第3步:归一化 + 仿射变换

LayerNorm ( x ) = γ ⊙ x − μ σ 2 + ϵ + β \text{LayerNorm}(\mathbf{x}) = \gamma \odot \frac{\mathbf{x} - \mu}{\sqrt{\sigma^2 + \epsilon}} + \beta LayerNorm(x)=γ⊙σ2+ϵ x−μ+β

其中:

  • d d d 是特征维度的大小
  • μ \mu μ 是该样本所有特征的均值, σ 2 \sigma^2 σ2 是方差
  • ϵ \epsilon ϵ 是很小的常数(如 10 − 5 10^{-5} 10−5),防止除以零
  • γ \gamma γ(缩放)和 β \beta β(偏移)是可学习参数,形状与特征维度相同

3. 计算示例 🔍

本章通过一个具体数值演示 LayerNorm 的计算过程

假设输入向量 x = [ 2.0 , 4.0 , 6.0 ] \mathbf{x} = [2.0, 4.0, 6.0] x=[2.0,4.0,6.0], ϵ = 10 − 5 \epsilon = 10^{-5} ϵ=10−5:

  • 均值 : μ = 2.0 + 4.0 + 6.0 3 = 4.0 \mu = \frac{2.0 + 4.0 + 6.0}{3} = 4.0 μ=32.0+4.0+6.0=4.0
  • 方差 : σ 2 = ( 2.0 − 4.0 ) 2 + ( 4.0 − 4.0 ) 2 + ( 6.0 − 4.0 ) 2 3 ≈ 2.667 \sigma^2 = \frac{(2.0-4.0)^2 + (4.0-4.0)^2 + (6.0-4.0)^2}{3} \approx 2.667 σ2=3(2.0−4.0)2+(4.0−4.0)2+(6.0−4.0)2≈2.667
  • 归一化 : x ^ = [ 2.0 , 4.0 , 6.0 ] − 4.0 2.667 + 10 − 5 ≈ [ − 1.225 , 0 , 1.225 ] \hat{\mathbf{x}} = \frac{[2.0, 4.0, 6.0] - 4.0}{\sqrt{2.667 + 10^{-5}}} \approx [-1.225, 0, 1.225] x^=2.667+10−5 [2.0,4.0,6.0]−4.0≈[−1.225,0,1.225]
  • 仿射变换 : y = γ ⊙ [ − 1.225 , 0 , 1.225 ] + β \mathbf{y} = \gamma \odot [-1.225, 0, 1.225] + \beta y=γ⊙[−1.225,0,1.225]+β

如果 γ = [ 1 , 1 , 1 ] \gamma = [1,1,1] γ=[1,1,1], β = [ 0 , 0 , 0 ] \beta = [0,0,0] β=[0,0,0],则输出为 [ − 1.225 , 0 , 1.225 ] [-1.225, 0, 1.225] [−1.225,0,1.225]------均值为 0,方差为 1。网络通过训练 γ \gamma γ 和 β \beta β 来适应不同数据的需要。

4. LayerNorm vs BatchNorm ⚔️

本章对比 LayerNorm 和 BatchNorm 的核心区别

两者的本质区别在于归一化的维度不同

特性 BatchNorm LayerNorm
归一化维度 沿 batch 维度 沿 特征维度
统计量依赖 依赖 batch 中其他样本 仅依赖当前样本
受 batch size 影响 是(batch 小时效果差)
训练/推理行为 不同(需 running stats) 一致
适用领域 CV(图像分类等) NLP(Transformer、RNN 等)

为什么 Transformer 选择 LayerNorm?

在 NLP 任务中,语义特征是由上下文决定的------同一个词在不同句子中含义不同。LayerNorm 只在单个样本内部归一化,保留了句内各 token 特征之间的相对关系,不破坏语义结构。而 BatchNorm 沿 batch 方向归一化,会混合不同句子的特征,破坏了句内语义。

此外,NLP 中句子长度不一致、batch size 通常较小,LayerNorm 不受这些因素影响。

5. PyTorch 代码示例 💻

本章通过一个简单的代码示例展示 LayerNorm 的使用

python 复制代码
import torch                                              # 导入 PyTorch 核心库,提供张量运算
import torch.nn as nn                                     # 导入神经网络模块,包含 LayerNorm 层

# 使用 PyTorch 原生 LayerNorm
d_model = 512                                             # 特征维度大小,示例:Transformer 中 d_model=512
layernorm = nn.LayerNorm(normalized_shape=d_model)        # 创建 LayerNorm 层,示例:对 512 维特征归一化

# 模拟输入:batch_size=2, seq_len=10, d_model=512
x = torch.randn(2, 10, d_model)                           # 随机生成输入张量,形状 [2,10,512]
output = layernorm(x)                                     # 前向传播,数据流动:[2,10,512] → [2,10,512]

# 验证归一化效果:取第一个 batch 第一个 token 的特征向量
print(f"均值: {output[0,0].mean():.4f}")                  # 应接近 0.0000
print(f"方差: {output[0,0].var():.4f}")                   # 应接近 1.0000

在 Transformer 的编码器结构CSDN)中,LayerNorm 出现在每个子层之后的 Add & Norm 操作中,负责稳定训练过程。


最后更新时间:2026-05-25

相关推荐
黎阳之光12 小时前
黎阳之光:以原创硬核通信,定义无人系统与应急指挥新边界|7030‑46无线图数自组网电台技术解析
大数据·人工智能·物联网·算法·数字孪生
大模型最新论文速读13 小时前
GRPO 丢失的组内排序信息,LamPO 补回来了
论文阅读·人工智能·深度学习·机器学习·自然语言处理
徐安安ye13 小时前
FlashAttention算子深度解读:让大模型在昇腾NPU上跑得更快
人工智能
蝎子莱莱爱打怪13 小时前
零基础用AI写App?兄弟😂 醒醒吧,那只是个玩具罢了!
前端·人工智能·后端
数字时代全景窗13 小时前
DeepSeek的荣耀与Evolver的困局:中国AI创新的一体两面
大数据·人工智能·架构·软件工程
comcoo13 小时前
OpenClaw 接入 MiniMax 图文指南|极速上手配置
人工智能·minimax·openclaw安装包·龙虾ai·open claw部署
XMZHKYFW13 小时前
ACS Catalysis复旦大学蒋昆&韩国高丽大学Seoin Back:生成式AI加速电催化剂发现:CatGPT助力高效筛选2e⁻-ORR制H₂O₂催化剂
人工智能·量子化学·催化剂·机理分析
Liuyc-Code boy13 小时前
使用商汤办公小浣熊生成HTML论文分析文档
人工智能·opc
百度Geek说13 小时前
RenderFlow:百度垂类搜索展现服务的 Agentic 代码交付实践
人工智能