当前位置: 首页 > news >正文

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()

运行测试:

http://www.cnnetsun.cn/news/32782.html

相关文章:

  • AWS-Nuke 终极指南:彻底清理AWS账户的完整教程
  • Python性能测试终极指南:用pyperf工具包提升代码效率
  • InterviewThis:开发者面试必备的全面评估指南,助你找到理想工作环境
  • 5分钟快速上手:Yaak桌面API客户端终极使用指南
  • Intel RealSense深度相机标定完全指南:从基础到高级参数调整
  • 在线教育学习|基于java + vue在线教育学习系统(源码+数据库+文档)
  • 350万美元颠覆千亿模型格局:Cogito v2 109B MoE开启开源效率革命
  • 出行旅游安排|基于springboot出行旅游安排系统(源码+数据库+文档)
  • 学生管理|基于springboot学生管理系统(源码+数据库+文档)
  • 酒店预约|基于springboot 酒店预约系统(源码+数据库+文档)
  • K8s API Server:集群的大脑
  • 10、Samba网络服务:NetBIOS名称解析与浏览功能详解
  • 13、Samba文件与打印共享配置全解析
  • 6、SELinux 策略配置与 Web 应用限制实践
  • 17、SELinux调试与审计全解析
  • Qwen3-VL-8B-Thinking-FP8:80亿参数开启多模态AI普惠时代
  • ComfyUI与舆情监控系统联动:自动生成事件相关配图
  • 16、打造让用户满意的网络环境
  • 24、深入探究 Samba 安全与服务集成
  • 如何在Ubuntu 20.04上正确配置Intel RealSense L515相机支持:完整解决方案指南
  • Windows命令行工具终极指南:3分钟快速上手系统管理神器
  • 18、Unix系统进程监控与脚本实现
  • 25、磁盘分区监控与主机自动ping脚本详解
  • Android TV性能优化工具配置指南:三步告别卡顿与内存泄漏
  • Canvas动画性能优化终极指南:10个让动画流畅如丝的核心技巧
  • 320亿参数逆袭!GLM-Z1开源模型重塑企业AI推理范式
  • Microsoft Equation Editor 3.0 公式编辑器完全解决方案
  • spotDL音乐下载终极指南:从Spotify到本地的完美转换
  • springboot基于vue的题库管理系统_1jhwudo9(源码+lw+部署讲解+答辩ppt等)
  • 8、Red Hat Linux 用户管理与软件管理指南