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

相关推荐
冬奇Lab1 小时前
Agent 系列(21):Harness 测试工程——45 个测试怎么设计,以及它发现了什么 bug
人工智能·llm·agent
冬奇Lab1 小时前
每日一个开源项目(第133篇):EchoBird - 把 AI 工具的安装和部署做成傻瓜操作
人工智能·开源·资讯
IT_陈寒2 小时前
Redis的SETNX并发问题让我加了三天班
前端·人工智能·后端
用户5191495848454 小时前
Windows 渗透测试载荷加载器 POC 工具集
人工智能·aigc
大树884 小时前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
通信小呆呆4 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
施小赞4 小时前
普通 RAG vs GraphRAG 核心对比
人工智能·ai
EAIReport4 小时前
RuoYi-AI 企业级AI开发平台实战详解
人工智能
HelloWorld__来都来了4 小时前
【每日学术速报】2026-06-15
人工智能·具身智能
H__Rick5 小时前
自动对焦学习-3
人工智能·学习·计算机视觉