一文彻底搞懂Transformer - Training(模型训练)
*WMT 2014英德和英法数据集在用于训练Transformer模型之前,需要进行一系列的数据预处理步骤。**下载数据集:首先,从WMT官方网站或相关资源中下载WMT 2014英德和英法数据集。这些数据集通常包括训练集、验证集和测试集。解压数据集:将下载的数据集文件(如.tgz或.tar格式)解压到指定的目录中,以便进行后续处理。去除无关信息:从文本中去除HTML标签、特殊字符、URL链接等与翻
Transformer
Transformer模型的训练过程是一个复杂但高度优化的流程,旨在通过合理的数据选择、硬件配置、训练计划、优化器使用和正则化策略来训练出高性能的模型。
一、合理的数据选择
训练数据集:训练数据作为Transformer模型训练的基础,扮演着至关重要的角色。这些数据集通常包含大量的、经过精心标注的样本,这些样本覆盖了模型在特定任务中需要学习和识别的各种语言现象、结构和模式。
在自然语言处理(NLP)领域,常用的数据集包括WMT(Workshop on Machine Translation)系列的翻译数据集,如WMT 2014英德和英法数据集。
- WMT 2014英德数据集:在标准的WMT 2014英德数据集上进行了训练,该数据集包含约450万个句子对。句子使用字节对编码(Byte-Pair Encoding,BPE)进行编码,这样源语言和目标语言共享一个约37000个标记的词汇表。
WMT 2014英德数据
- WMT 2014英法数据集:对于英法数据集,使用了更大的WMT 2014英法数据集,包含3600万个句子,并将标记分为一个32000个词片段的词汇表。句子对根据序列长度的近似值进行批处理。每个训练批次包含一组句子对,这些句子对大约包含25000个源语言标记和25000个目标语言标记。
WMT 2014英法数据
**WMT 2014英德和英法数据集在用于训练Transformer模型之前,需要进行一系列的数据预处理步骤。**这些步骤包括文本清洗、分词与标记化、构建词汇表、子词单元生成(如BPE)、数值化以及添加特殊标记。
一、数据下载与解压
-
下载数据集:首先,从WMT官方网站或相关资源中下载WMT 2014英德和英法数据集。这些数据集通常包括训练集、验证集和测试集。
-
解压数据集:将下载的数据集文件(如.tgz或.tar格式)解压到指定的目录中,以便进行后续处理。
二、文本清洗
-
去除无关信息:从文本中去除HTML标签、特殊字符、URL链接等与翻译任务无关的信息。
-
纠正拼写和语法错误:虽然这不是预处理的主要任务,但在某些情况下,可能需要纠正文本中的拼写和语法错误,以提高数据质量。
三、分词与标记化
-
分词:将文本分割成更小的单元,如单词或子词。对于英语和德语,由于单词之间有空格分隔,分词相对简单。但对于其他语言,可能需要使用专门的分词工具。
-
标记化:将分词后的文本转换为模型可以处理的标记(tokens)。这通常涉及将单词或子词转换为唯一的标识符(如整数ID)。
四、构建词汇表
-
提取唯一标记:从训练数据中提取所有唯一的标记(如单词或子词)。
-
构建词汇表:将提取的标记组织成一个词汇表,并为其分配唯一的索引(ID)。词汇表的大小和构成对模型的性能有一定影响。
五、子词单元生成(如BPE)
-
使用子词单元技术:如Byte Pair Encoding(BPE),将单词分割成更小的子词单元。这有助于处理未登录词(OOV)问题,并提高模型的泛化能力。
-
生成BPE词汇表:使用BPE算法对训练数据进行处理,生成包含子词单元的词汇表。
六、数值化
- 文本转ID:将文本数据中的每个标记(或子词单元)替换为其在词汇表中的索引(ID)。
七、添加特殊标记
-
开始和结束标记:在序列的开始和结束处添加特殊的标记,如
<s>
和</s>
,以指示句子的边界。 -
其他特殊标记:根据需要添加其他特殊标记,如填充标记(
<pad>
)或分隔标记(<sep>
)。
__二、_硬件配置___
在配备高性能NVIDIA P100 GPU的机器上训练Transformer模型的效率是非常高的。无论是基础模型还是大型模型,都能够在合理的时间内完成训练,这得益于P100 GPU的强大计算能力和高带宽内存。
基础模型训练:
-
硬件环境:8个NVIDIA P100 GPU,每个GPU具有强大的并行计算能力和高带宽内存。
-
训练时间:每步训练大约需要0.4秒,总共训练100,000步,因此总体训练时间约为12小时(0.4秒/步 * 100,000步 = 40,000秒 ≈ 11.11小时,四舍五入为12小时)。
-
性能特点:基础模型由于参数较少,计算量相对较低,因此能够在相对较短的时间内完成训练。
大型模型训练:
-
硬件环境:同样使用8个NVIDIA P100 GPU,但由于模型规模增大,每步训练的计算量显著增加。
-
训练时间:每步训练需要1.0秒,总共训练300,000步,因此总体训练时间约为3.5天(1.0秒/步 * 300,000步 = 300,000秒 ≈ 3.47天,四舍五入为3.5天)。
-
性能特点:大型模型由于参数众多,计算复杂度高,需要更长的训练时间。然而,得益于P100 GPU的强大计算能力,这种训练仍然可以在合理的时间内完成。
三、训练计划____
模型构建与训练使用深度学习框架根据预设超参数建立模型并训练以提取数据特征,而模型评估与优化则是通过测试集验证模型性能并据此调整模型以提高其泛化能力。
模型训练
模型构建与训练:
- 模型构建:
-
根据论文或实验需求选择合适的模型架构,如Transformer。
-
设置超参数,如学习率、批次大小、优化器(Adam、SGD等)、训练轮次等。
-
使用深度学习框架提供的API构建模型。
- 训练过程:
-
加载训练数据,并进行批次处理。
-
使用训练数据对模型进行迭代训练,每个批次计算损失函数并更新模型权重。
-
在每个训练周期(epoch)结束时,使用验证集评估模型性能,并记录关键指标(如准确率、损失值)。
- 模型保存:
-
在训练过程中定期保存模型权重和参数,以便在需要时恢复训练或进行模型评估。
-
保存最佳模型(即验证集上性能最好的模型)。
模型评估与优化:
- 模型评估:
-
使用测试集对训练好的模型进行评估,确保评估过程与训练过程完全独立。
-
计算并记录关键性能指标,如准确率、召回率、F1分数等。
- 模型优化:
-
根据评估结果调整超参数,如学习率、批次大小等。
-
尝试不同的模型架构或改进现有架构。
-
使用正则化、dropout等技术防止过拟合。
-
应用集成学习方法(如模型平均、模型融合)提高整体性能。
- 结果分析:
-
分析模型在不同数据集上的表现,识别潜在的偏差或不足。
-
根据业务需求调整评估指标或评估方法。
__四、_优化器使用___
Transformer使用了Adam优化器,并设置其超参数为β1=0.9,β2=0.98,以及ϵ=10−9。在学习过程中,根据以下公式调整学习率:
这种动态调整的方法通常基于训练过程中的一些指标或条件,如训练轮数、验证集性能等,来实时调整学习率的大小。根据公式(1)的计算方式,模型在训练过程中学习率的变化如图所示:
Adam优化器:Adam(Adaptive Moment Estimation)优化器是一种结合了AdaGrad和RMSProp优点的高效优化算法******,它广******泛应用于深度学习模型的训练中。
Adam基于随机梯度下降算法,通过计算梯度的一阶矩估计(即梯度的均值)和二阶矩估计(即梯度的未中心化的方差)来综合考虑,从而计算出更新步长。
-
自适应性:能够自适应地调整每个参数的学习率,从而更好地适应不同参数之间的差异。
-
有效性:使用了动量和二阶动量信息来更新参数,使模型训练更加平稳和快速。
-
鲁棒性:对于噪声较多或稀疏数据集也具有很好的鲁棒性。
-
参数范围不变性:能够保持对参数范围变化的不敏感性,在实际应用中比其他优化算法更为稳定。
五、正则化策略____
Transformer模型使用了多种正则化方法来减少过拟合现象,提高模型的泛化能力。三种正则化方法如下:
-
Layer Normalization:对每个子层的输出进行归一化处理,使得每个神经元输入的分布更加稳定,这有利于模型的训练和泛化性能。
-
Dropout:在训练过程中随机地将一部分神经元的输出设置为0,从而减少不同神经元之间的依赖关系,避免模型过拟合。这种方法可以防止模型过分依赖于某些特定输入,从而提高模型的泛化能力。
-
注意力机制中的随机Drop Key:在注意力计算阶段,通过随机drop部分Key来鼓励网络捕获目标对象的全局信息,从而避免了由过于聚焦局部信息所引发的模型偏置问题,进而提升了模型的精度。这种方法通常被用于基于Transformer的视觉类算法中。
如何学习大模型 AI ?
由于新岗位的生产效率,要优于被取代岗位的生产效率,所以实际上整个社会的生产效率是提升的。
但是具体到个人,只能说是:
“最先掌握AI的人,将会比较晚掌握AI的人有竞争优势”。
这句话,放在计算机、互联网、移动互联网的开局时期,都是一样的道理。
我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。
我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在人工智能学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。但苦于知识传播途径有限,很多互联网行业朋友无法获得正确的资料得到学习提升,故此将并将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。
第一阶段(10天):初阶应用
该阶段让大家对大模型 AI有一个最前沿的认识,对大模型 AI 的理解超过 95% 的人,可以在相关讨论时发表高级、不跟风、又接地气的见解,别人只会和 AI 聊天,而你能调教 AI,并能用代码将大模型和业务衔接。
- 大模型 AI 能干什么?
- 大模型是怎样获得「智能」的?
- 用好 AI 的核心心法
- 大模型应用业务架构
- 大模型应用技术架构
- 代码示例:向 GPT-3.5 灌入新知识
- 提示工程的意义和核心思想
- Prompt 典型构成
- 指令调优方法论
- 思维链和思维树
- Prompt 攻击和防范
- …
第二阶段(30天):高阶应用
该阶段我们正式进入大模型 AI 进阶实战学习,学会构造私有知识库,扩展 AI 的能力。快速开发一个完整的基于 agent 对话机器人。掌握功能最强的大模型开发框架,抓住最新的技术进展,适合 Python 和 JavaScript 程序员。
- 为什么要做 RAG
- 搭建一个简单的 ChatPDF
- 检索的基础概念
- 什么是向量表示(Embeddings)
- 向量数据库与向量检索
- 基于向量检索的 RAG
- 搭建 RAG 系统的扩展知识
- 混合检索与 RAG-Fusion 简介
- 向量模型本地部署
- …
第三阶段(30天):模型训练
恭喜你,如果学到这里,你基本可以找到一份大模型 AI相关的工作,自己也能训练 GPT 了!通过微调,训练自己的垂直大模型,能独立训练开源多模态大模型,掌握更多技术方案。
到此为止,大概2个月的时间。你已经成为了一名“AI小子”。那么你还想往下探索吗?
- 为什么要做 RAG
- 什么是模型
- 什么是模型训练
- 求解器 & 损失函数简介
- 小实验2:手写一个简单的神经网络并训练它
- 什么是训练/预训练/微调/轻量化微调
- Transformer结构简介
- 轻量化微调
- 实验数据集的构建
- …
第四阶段(20天):商业闭环
对全球大模型从性能、吞吐量、成本等方面有一定的认知,可以在云端和本地等多种环境下部署大模型,找到适合自己的项目/创业方向,做一名被 AI 武装的产品经理。
- 硬件选型
- 带你了解全球大模型
- 使用国产大模型服务
- 搭建 OpenAI 代理
- 热身:基于阿里云 PAI 部署 Stable Diffusion
- 在本地计算机运行大模型
- 大模型的私有化部署
- 基于 vLLM 部署大模型
- 案例:如何优雅地在阿里云私有部署开源大模型
- 部署一套开源 LLM 项目
- 内容安全
- 互联网信息服务算法备案
- …
学习是一个过程,只要学习就会有挑战。天道酬勤,你越努力,就会成为越优秀的自己。
如果你能在15天内完成所有的任务,那你堪称天才。然而,如果你能完成 60-70% 的内容,你就已经开始具备成为一名大模型 AI 的正确特征了。
这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
更多推荐
所有评论(0)