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 ϵ 是很小的常数(如 1 0 − 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 ϵ = 1 0 − 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 + 1 0 − 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

相关推荐
Jooolin4 小时前
从 DeepSeek、Qwen 到 GPT:一次企业级 AI 知识库项目的模型选型复盘
人工智能·云原生·ai编程
不羁的木木4 小时前
HarmonyOS AI开发提效工具:DevEco Code & DevEco CLI - 实战:端侧AI文字识别应用
人工智能·华为·harmonyos
蓝速科技4 小时前
蓝速科技 AI 数字人导办能力实测与人机协同价值评估
人工智能·科技
云和数据.ChenGuang5 小时前
T5大模型
人工智能·机器人·pandas·数据预处理·数据训练
哈哈,柳暗花明5 小时前
人工智能专业术语详解(O)
人工智能·专业术语
不羁的木木5 小时前
HarmonyOS AI开发提效工具:DevEco Code & DevEco CLI - 初识与配置指南
人工智能·华为·harmonyos
Kagol5 小时前
Superpowers GSD gstack AgentSkills深度测评
前端·人工智能
一切皆是因缘际会5 小时前
存算一体芯片软件双模式:单字符驱动网络(普通CPU也能跑)
人工智能·物联网·ai·系统架构·架构设计·发布订阅·存算一体
字节逆旅5 小时前
Claude Code Router 接入过程的爬坑记录
人工智能·claude
江畔柳前堤5 小时前
github实战指南01-账号配置与 SSH 密钥
运维·人工智能·深度学习·ssh·github·pyqt·信号处理