news 2026/6/10 16:25:37

Transformer 大语言模型(LLM)基石 - Transformer架构详解 - 层归一化(Layer Normalization)详解以及算法实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Transformer 大语言模型(LLM)基石 - Transformer架构详解 - 层归一化(Layer Normalization)详解以及算法实现

锋哥原创的Transformer 大语言模型(LLM)基石视频教程:

https://www.bilibili.com/video/BV1X92pBqEhV

课程介绍

本课程主要讲解Transformer简介,Transformer架构介绍,Transformer架构详解,包括输入层,位置编码,多头注意力机制,前馈神经网络,编码器层,解码器层,输出层,以及Transformer Pytorch2内置实现,Transformer基于PyTorch2手写实现等知识。

Transformer 大语言模型(LLM)基石 - Transformer架构详解 - 层归一化(Layer Normalization)详解以及算法实现

层归一化(LayerNorm)是对输入的每一维特征进行归一化,使得网络在训练过程中保持稳定。

公式:

优点:

  1. 稳定性:层归一化可以防止输入值的范围过大或过小,使得训练过程更加稳定。

  2. 与批大小无关:不像批归一化依赖于批量大小,层归一化是针对每个样本单独进行归一化,非常适合序列模型。

代码实现:

# 层归一化 class LayerNorm(nn.Module): # features 512 词嵌入维度 eps 极小值常数,防止零分母 def __init__(self, features, eps=1e-6): super().__init__() self.gamma = nn.Parameter(torch.ones(features)) # 可学习的缩放参数 self.beta = nn.Parameter(torch.zeros(features)) # 可学习的平移参数 self.eps = eps def forward(self, x): """ 前向传播 参数: x: 输入张量 [batch_size, seq_len, d_model] [3,5,512] 来自多头自注意力机制,或者来自前馈神经网络 返回: 归一化后的张量 """ mean = x.mean(-1, keepdim=True) # 计算均值 [3,5,512] variance = x.var(-1, keepdim=True) # 计算方差 [3,5,512] x = (x - mean) / torch.sqrt(variance + self.eps) # 归一化 [3,5,512] return self.gamma * x + self.beta if __name__ == '__main__': vocab_size = 2000 # 词表大小 embedding_dim = 512 # 词嵌入维度的大小 embeddings = Embeddings(vocab_size, embedding_dim) embed_result = embeddings( torch.tensor([[1999, 2, 99, 4, 5], [66, 2, 3, 22, 5], [66, 2, 3, 4, 5]])) print("embed_result.shape:", embed_result.shape) print("embed_result", embed_result) positional_encoding = PositionalEncoding(embedding_dim) result = positional_encoding(embed_result) print("result:", result) print("result.shape:", result.shape) # 测试自注意力机制 # query = key = value = result # mask = create_sequence_mask(5) # dropout = nn.Dropout(0.1) # attention_output, attention_weights = self_attention(query, key, value, mask, dropout) # print("attention_output.shape:", attention_output.shape) # [3, 5, 512] # print("attention_weights.shape:", attention_weights.shape) # [3, 5, 5] mha = MultiHeadAttention(d_model=512, num_heads=8) print(mha) mask = create_sequence_mask(5) result = mha(result, result, result, mask) print("result.shape:", result.shape) # [3, 5, 512] # 测试前馈神经网络 # ffn = FeedForward(d_model=512, d_ff=2048) # ffn_result = ffn(result) # print('ffn_result:', ffn_result.shape) # 测试层归一化 ln = LayerNorm(features=512) ln_result = ln(result) print("ln_result:", ln_result.shape)

运行结果:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 10:46:23

算法备案五大类型:如何为你的算法精准“画像”?

跟着《互联网信息服务算法推荐管理规定》的实施,算法备案变为众多企业必须要直面的合规现实。但对于第一次进行备案的企业来说,最先遇到的疑问不是材料资质的问题,而是:“我的算法,究竟该归属于哪一类?” 这…

作者头像 李华
网站建设 2026/6/10 10:37:19

OpenAI绝地反击:GPT-5.2紧急上线,以“最强职场模型”硬刚Gemini 3

【摘要】OpenAI紧急发布GPT-5.2,精准定位“最强职场模型”,以应对谷歌Gemini 3的竞争压力。此举标志着AI从通用助手向深度赋能专业工作流的生产力工具演进。引言AI领域的竞争节奏正在以超乎想象的速度加快。距离上一代模型发布不足一月,OpenA…

作者头像 李华
网站建设 2026/6/9 22:35:21

超细致的性能测试流程,你get了吗?

性能测试:利用工具模拟大量用户操作,验证系统承受的负载情况。 性能测试的目的:找到潜在的性能问题或瓶颈,分析并解决;找出性能变化趋势,为后续扩展系统提供参考。 测试监控:基准测试、配置测…

作者头像 李华
网站建设 2026/6/10 7:57:34

TorchAO完整指南:掌握量化与稀疏化技术快速提升AI模型性能

TorchAO完整指南:掌握量化与稀疏化技术快速提升AI模型性能 【免费下载链接】ao Native PyTorch library for quantization and sparsity 项目地址: https://gitcode.com/GitHub_Trending/ao2/ao 想要让你的PyTorch模型运行更快、占用更少资源吗?T…

作者头像 李华
网站建设 2026/6/10 11:52:00

云端算力:数字时代的核心引擎与创新基石

云端算力:数字时代的核心引擎与创新基石在数字经济加速渗透的今天,云端算力正以不可逆转的趋势重塑产业格局。从AI大模型训练到工业互联网实时分析,从元宇宙场景构建到全球科研协作,云端算力已成为驱动技术突破、产业升级与社会进…

作者头像 李华
网站建设 2026/6/10 10:43:08

Day33 类的装饰器

知识点: 1.类的装饰器 2.装饰器思想的进一步理解:外部修改、动态 3.类方法的定义:内部定义和外部定义 浙大疏锦行

作者头像 李华