news 2026/6/10 12:53:31

Transformer 大语言模型(LLM)基石 - Transformer架构详解 - 编码器(Encoder)详解以及算法实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Transformer 大语言模型(LLM)基石 - Transformer架构详解 - 编码器(Encoder)详解以及算法实现

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

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

课程介绍

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

Transformer 大语言模型(LLM)基石 - Transformer架构详解 - 编码器(Encoder)详解以及算法实现

编码器结构:

  1. 多头自注意力 (MHA):每个位置对整句做“信息汇聚”。

  2. 前馈网络 (FFN):逐位置的两层 MLP(常用维度 d_ff=4×d_model)。

  3. 残差连接 + LayerNorm:稳定训练、加速收敛。

代码实现:

# 编码器层 class EncoderLayer(nn.Module): def __init__(self, d_model, self_attention, d_ff, dropout=0.1): super().__init__() self.d_model = d_model self.self_attention = self_attention # 多头自注意力机制 self.feed_forward = d_ff # 前馈神经网络 self.residual_connection1 = ResidualConnection(d_model, dropout) # 残差连接 self.residual_connection2 = ResidualConnection(d_model, dropout) # 残差连接 def forward(self, x): """ 前向传播 参数: x: 输入张量 [batch_size, seq_len, d_model] mask: 掩码张量 [batch_size, seq_len, seq_len] 返回: 编码器层的输出张量 """ # 多头自注意力机制 x1 = self.residual_connection1(x, lambda x: self.self_attention(x, x, x)) # 多头自注意力机制 x2 = self.residual_connection2(x1, lambda x: self.feed_forward(x)) # 前馈神经网络 return x2 # 编码器 (由多个编码器层堆叠) class Encoder(nn.Module): def __init__(self, num_layers, layer): super().__init__() self.layers = nn.ModuleList([copy.deepcopy(layer) for _ in range(num_layers)]) self.norm = LayerNorm(layer.d_model) def forward(self, x): """ 前向传播 输入: x: 输入张量 [batch_size, seq_len, d_model] 返回: 编码器的输出张量 [batch_size, seq_len, d_model] """ for layer in self.layers: x = layer(x) return self.norm(x) # 测试编码器 def test_encoder(): 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]])) positional_encoding = PositionalEncoding(embedding_dim) positional_result = positional_encoding(embed_result) mha = MultiHeadAttention(d_model=512, num_heads=8) # 多头自注意力机制 ffn = FeedForward(d_model=512, d_ff=2048) # 前馈神经网络 encoder_layer = EncoderLayer(d_model=512, self_attention=mha, d_ff=ffn) # 编码器层 # 实例化编码器对象 encoder = Encoder(num_layers=6, layer=encoder_layer) encoder_result = encoder(positional_result) print('encoder_result.shape:', encoder_result.shape) if __name__ == '__main__': test_encoder()

运行测试:

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

Go语言多版本管理实战:从环境混乱到开发效率提升300%

还在为不同Go项目间的版本切换而烦恼吗?一个需要Go 1.18的项目,另一个要求Go 1.21,切换一次环境就要重新配置所有工具链?本文将带你通过实战案例,彻底解决Go语言多版本管理难题。 【免费下载链接】tools [mirror] Go T…

作者头像 李华
网站建设 2026/6/9 20:17:19

GyroFlow视频稳定软件OpenFX插件权限问题完全解决方案

GyroFlow视频稳定软件OpenFX插件权限问题完全解决方案 【免费下载链接】gyroflow Video stabilization using gyroscope data 项目地址: https://gitcode.com/GitHub_Trending/gy/gyroflow GyroFlow作为专业的陀螺仪数据视频稳定软件,在最新版本中为用户提供…

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

JMusicBot深度使用指南:10个高级技巧提升Discord音乐体验

JMusicBot深度使用指南:10个高级技巧提升Discord音乐体验 【免费下载链接】MusicBot 🎶 A Discord music bot thats easy to set up and run yourself! 项目地址: https://gitcode.com/GitHub_Trending/mu/MusicBot JMusicBot作为一款优秀的跨平台…

作者头像 李华
网站建设 2026/6/10 15:39:27

Android抓包神器HttpCanary实战指南:从零掌握网络调试与安全分析

在移动应用开发和网络安全分析领域,能够准确捕获和分析网络请求是至关重要的技能。HttpCanary作为Android平台上的专业级抓包工具,为开发者提供了强大的网络调试和安全分析能力。本文将带你从基础配置到高级应用,全面掌握这款工具的使用技巧。…

作者头像 李华
网站建设 2026/6/3 15:27:29

DeepSeek-V3.1:智能计算新纪元的开启者

DeepSeek-V3.1:智能计算新纪元的开启者 【免费下载链接】DeepSeek-V3.1 项目地址: https://ai.gitcode.com/hf_mirrors/deepseek-ai/DeepSeek-V3.1 当企业面对海量数据处理需求时,如何在保证推理精度的同时实现毫秒级响应?这一直是AI…

作者头像 李华
网站建设 2026/6/9 15:16:04

CreamApi终极指南:3步轻松解锁游戏DLC的简单方法

CreamApi终极指南:3步轻松解锁游戏DLC的简单方法 【免费下载链接】CreamApi 项目地址: https://gitcode.com/gh_mirrors/cr/CreamApi 还在为心仪的游戏DLC价格昂贵而烦恼吗?CreamApi作为一款专业的游戏DLC自动解锁配置工具,能够帮助你…

作者头像 李华