0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

大模型工业化的方法论,都藏在 GPU 里

NVIDIA英伟达 来源:未知 2023-01-07 20:05 次阅读

本文转载自DataFunTalk

编辑推荐

大模型已经是人工智能的基础设施了,如何进一步普惠商用并盈利是当务之急。近日,NVIDIA 邀请百度、字节跳动火山翻译、腾讯微信等 6 位专家,围绕“AI 大模型技术路线和工业化落地实践”展开分享,以下为分享内容精华汇总。

数据智能时代,计算是刚需,也是痛点,最主要的特点就是一个字——大。

将“大”拆分成三个特点,则包括:

  • 数据大批量

  • 计算串行依赖

  • 计算复杂性高

这囊括了数据和算法的复杂性,而数据、算法、算力是智能时代三要素,前两者的复杂性最后都要由算力来承载。

这使得业界对算力的需求在空间和时间上都极速膨胀,有如海啸之势。

GPU 却有办法将海啸在空间上细分成万千条涓涓细流,在时间上缩短流水的路径,在结构上精简路径分支,将大规模任务层层拆解成小规模任务,举重若轻般承载了海量算力需求,成为智能时代的算力基础。

针对上述三个特点,GPU 基于吞吐量、显存等指标,分别采用并行、融合、简化三种方法,在算子层面进行加速。

GPU 加速的主要方法论,亦适用于大模型的工业化。

伴随底层芯片、算力、数据等基础设施的完善和进步,全球 AI 产业正逐步从运算智能走向感知智能、认知智能,并相应形成“芯片、算力设施、AI 框架&算法模型、应用场景”的产业分工、协作体系。2019 年以来,AI 大模型带来问题泛化求解能力大幅提升,“大模型+小模型”逐步成为产业主流技术路线,驱动全球 AI 产业发展全面加速。

从 NVIDIA、百度、字节跳动火山翻译、腾讯微信等几位专家的分享,我们也不难发现,他们在业界落地大模型的时候,很大程度上都采用了并行、融合与简化的方法,并且还从训练、推理层面延伸到了算法建模层面。

01

并行

并行方法是一种空间换时间的方法,它将海啸细分成涓涓细流。具体而言,对于数据大批量的计算,每个计算步骤的耗时都比较长。GPU 利用并行计算,也就是把没有计算依赖的数据尽可能并行,把大批量拆分成小批量,以减少每个计算步骤的 GPU 空闲等待时间,提高计算吞吐量。

为了实际完成大模型的训练,就需要高效率的软件框架,使得训练在单个 GPU、单个节点甚至在大规模集群上都有很好的计算效率。

因此,NVIDIA 开发出了 Megatron 训练框架。

Megatron 采用了模型并行、Sequence 并行等优化手段以高效地训练 Transformer 大模型,可训练万亿级别参数量的模型。

在算法建模层面,火山翻译和百度主要对 MoE 模型等建模方法进行了探索。

1. 模型并行

模型并行可分为 Pipeline 并行和 Tensor 并行。

eedd30ae-8e81-11ed-bfe3-dac502259ad0.png

Pipeline 并行也就是层间并行(图中上半部分),将不同的层划分到不同的 GPU 进行计算。这种模式的通信只发生在层的边界,通信次数和通信数据量较少,但会引入额外的 GPU 空间等待时间。

Tensor 并行也就是层内并行(图中下半部分),将一个层的计算划分到不同的 GPU 上计算。这种模式的实现更加容易,对于大矩阵的效果更好,更好实现 GPU 之间的负载均衡,但通信次数和数据量都比较大。

efa3e0a0-8e81-11ed-bfe3-dac502259ad0.png

为了充分利用 GPU 资源,Megatron 将每个训练 batch 划分成了更小的 micro batch。

由于不同的 micro batch 之间没有数据依赖,因此可以互相覆盖等待时间,从而能够提高 GPU 的利用率,进而提高整体的训练性能。

efd820ae-8e81-11ed-bfe3-dac502259ad0.png

Tensor 并行把每个算子的计算划分到不同的 GPU 上,对于一个矩阵层,存在横切和纵切两种方式。

如图所示,Megatron 在 Transformer block 的 attention 和 MLP 部分都引入了这两种切分方式。

f0017684-8e81-11ed-bfe3-dac502259ad0.png

在 Tensor 并行模式下,每个 Transformer 层的前向反向加起来总共需要四次 All-reduce 通信,由于 All-reduce 的通信量较大,因此 Tensor 并行更适合单卡内部使用。

结合 Pipeline 并行和 Tensor 并行,Megatron 可以将在 32 个 GPU 上训练 1700 亿参数模型,扩展到在 3072 个 GPU 上训练 1 万亿参数规模的模型。

2. Sequence 并行

Tensor 并行其实并没有对 Layer-norm 以及 Dropout 做拆分,因此这两个算子在每个 GPU 之间是复制的。

然而,这些操作本身不需要大量计算,却非常占用激活显存。

f0381afe-8e81-11ed-bfe3-dac502259ad0.png

为此,Megatron 又提出了 Sequence 并行的优化方法。Sequence 并行的好处在于不会增加通信量,并且可以大大减少显存占用

由于 Layer-norm 和 Dropout 沿着序列的维度是独立的,因此可以按照 Sequence 维度进行拆分。

使用了 Sequence 并行之后,对于超大规模的模型而言,其实显存占用量还是很大的。因此,Megatron 又引入了激活重计算技术。

Megatron 的做法是,找到一些计算量很少但显存占用很大的算子,比如 Attention 里的 Softmax、Dropout 等算子,对这些算子进行激活重计算就可以显著减少显存,并且计算开销增加不大。

Sequence 并行和选择性激活重计算的结合可以将显存占用降低为原来的 1/5 左右。相对于原本直接将所有激活进行重计算的方案,其显存也只有其两倍,同时计算开销显著降低,并且随着模型规模增大,计算开销的占比也会逐渐降低。到万亿规模模型的时候,重计算的开销只占整体的 2% 左右。

3. 算法并行

MoE 模型因其设计思想简洁、可扩展性强等特点,使其在业界得到了越来越多的关注。

MoE 模型提出了这样的设计思想,也就是将大模型拆分成多个小模型。每个样本只需要激活部分专家模型进行计算,从而大大节省计算资源。

f0720fa2-8e81-11ed-bfe3-dac502259ad0.png

目前最常用的稠密大模型是 BERT、T5、GPT-3,最常用的稀疏 MoE 模型是 T5+MoE,MoE 正成为大模型构建的趋势。

可以说,MoE 在算法建模层面,结合了并行计算的思想。

大模型的通用性,体现在多个方面,除了我们已经熟知的几点,比如注意力机制归纳偏置更弱,模型容量大,模型数据大等等,还可以在任务建模方式上做优化,MoE 就是典型的代表。

对于火山翻译而言,MoE 的基本思路是通过宽度换取深度,因为模型深度越深,计算层数越多,进而推理时间越长。

f08f4d88-8e81-11ed-bfe3-dac502259ad0.png

比如,对于拥有 4 层 Encoder、4 层 Decoder 的 Transformer 模型,每次计算必须经过所有 8 个 FFN 的计算。如果是混合专家模型,则可以把 FFN 平行放置,最终把计算路径减半,因而推理时间也减半。

f0d883cc-8e81-11ed-bfe3-dac502259ad0.png

而在相同推理时间下,也就是模型深度相近的时候,由于 MoE 可以增加模型宽度,在机器翻译的最终效果上也有所提升。

f10da5ca-8e81-11ed-bfe3-dac502259ad0.png

针对 24 种非洲语言和英、法语言的多语言翻译任务,火山翻译开发出了拥有 128 层 Transformer、24 个专家层的 MoE 模型,相比传统架构实现了更好的翻译效果。

f138eb72-8e81-11ed-bfe3-dac502259ad0.png

但 Sparse MoE 中的“专家模型”可能有些名不副实,因为对于一句话,比如其每个 Token 经过的专家都有可能是不同的。

火山翻译因此开发了 Hard Gate MoE,使得句子经过的专家由语种确定,这使得模型结构更加简单,实验结果也表明其翻译效果更好。

在算法建模的并行化探索中,百度也在知识增强跨模态生成大模型 ERNIE-ViLG 2.0 中采用了混合专家扩散模型框架。

f1a78546-8e81-11ed-bfe3-dac502259ad0.png

为何要对扩散模型采用专家模型?

其实是因为在不同的生成阶段,模型建模要求的不同。比如在初始阶段,模型着重学习从高斯噪声中生成有语义的图像,在最后阶段,模型着重从含噪图像中恢复图像细节。

实际上,在 ERNIE 3.0 的早期版本中就融合了自编码和自回归,其可在通用的语义表示上,针对具体的生成任务和理解任务,结合两种建模方式。

f21c0326-8e81-11ed-bfe3-dac502259ad0.png

融合自编码和自回归的基本思想其实与专家模型的建模方法论类似。

具体来说,是在通用表示的基础上,根据理解任务适合自编码网络结构,生成任务适合自回归网络结构,来进行建模。此外,这种建模方式通常还能学习到更好的通用表示。

f29bf112-8e81-11ed-bfe3-dac502259ad0.png

此外,在 ERNIE-UniX2 模型中,百度通过将对比学习、语言模型等预训练范式进行融合,将多语言、多模态的理解和生成任务进行了统一。

训练完 MoE 模型后,推理部署也是非常重视效率的环节。

在进行超大规模模型推理部署方案选择的时候,首先会根据模型的参数规模、模型结构、GPU 显存和推理框架,以及对模型精度和推理性能的权衡来决定是使用单卡推理还是多卡推理。如果显存不足,则会考虑模型压缩或多卡推理的方案。

多卡推理包括 Tensor 并行、Pipeline 并行、Expert 并行等模式。

f2c693e0-8e81-11ed-bfe3-dac502259ad0.png

对 MoE 超大模型采用不同模式会遇到不同的挑战。其中,MoE 模型的 Tensor 并行和稠密模型类似。

如果选择 Expert 并行模式,每个 MoE Layer 的 Expert 就会被划分到不同的 GPU 上,这可能带来负载均衡问题,从而导致大量的 GPU 是空闲的,最终使得整体吞吐量不高。这是 MoE 多卡推理中需要关注的重点。

对于 Tensor 并行和 Pipeline 并行,除了通过微调减少卡间通讯以外,更直接的方法是提升卡间带宽。而当对 MoE 模型使用 Expert 并行导致负载均衡问题的时候,可以通过 Profiling 分析优化。

多卡推理方案增加了通信开销,对模型推理延时有一定影响。

02

融合

融合是解决并行计算中遇到的天然矛盾的方法,并行计算和串行计算是两种基本的计算模式。而在应用并行计算的时候,最典型的困难就是大量的串行依赖,以及因此产生的中间值显存占用问题,而 GPU 显存通常会成为大模型训练和推理的硬件性能瓶颈之一。

对于海量计算串行依赖问题,最主要的方法是将细流的路径缩短,也就是减少中间停留过程。具体来说,就是利用算子融合,把次序存在先后依赖关系的算子进行合并,以减少显存占用。

算子融合不仅在计算层面,也可以在算子设计层面实现。

1. 1F1B

Pipeline 并行中如果将前向和反向过程分开,就会出现显存占用过多问题。

f3177684-8e81-11ed-bfe3-dac502259ad0.png

因此,Megatron 又提出了 Pipeline 并行的新模式 1F1B,每个 GPU 以交替的方式执行每个 micro batch 的正向和反向过程,以尽早释放其占用的显存,进而减少显存占用。

f35c73c4-8e81-11ed-bfe3-dac502259ad0.png

1F1B 并不能减少 bubble time,为了进一步减少 bubble time,Megatron 又提出了 interleaved 1F1B 模式。也就是原本每个 GPU 负责连续 4 个层的计算,现在变成负责连续两个层的计算,只有原来的一半,从而 bubble time 也变成了原来的一半。

2. Kernel 融合

当在做 GPU 计算的时候,每个计算流程都可以封装成一个 GPU 的 Kernel,放到 GPU 上执行,并且是顺序性的。传统的算子库为了通用性,会把算子设计的非常基本,因此数量也非常多,带来的弊端是显存占用多,因为需要存储大量的中间隐藏表示,另外这对带宽的要求也比较高,最终可能造成延迟或者性能损失。

f3b371a6-8e81-11ed-bfe3-dac502259ad0.png

火山翻译基于 CuBLAS 乘法接口将其他非矩阵乘法算子进行了融合,包括了 Softmax、LayerNorm 等。

f3dd976a-8e81-11ed-bfe3-dac502259ad0.png

除了比较通用算子的融合,火山翻译还针对一些特定算子比如 Beam Search 无法很好利用 GPU 并行性的特点,优化其计算依赖问题,从而实现加速。

在四种主流 Transformer 模型上,LightSeq 算子融合在 PyTorch 的基础上取得了最高 8 倍的加速。

03

简化

简化是一种比较简单直观的加速方式,在细微处将流水分支精简。具体而言,就是对于计算高复杂性,在保证性能的前提下将算子复杂度简化,最终减少计算量。

超大规模模型的单卡推理一般会涉及模型压缩。

f4179df2-8e81-11ed-bfe3-dac502259ad0.png


常见的模型压缩方案是量化、蒸馏和剪枝。量化是业内最常用的模型压缩方案之一。虽然量化的计算采用了更低的精度,但可以保持模型的参数量级,在某些情况下或许能更好地保证模型整体的精度。

1. 量化

f44094fa-8e81-11ed-bfe3-dac502259ad0.png

目前有两种量化方法,一种是训练后量化,一种是量化感知训练。后者通常比前者对模型的精度保持更好。

完成量化后,可以通过 TensorRT 或 FasterTransformer 等推理加速框架,进一步加速超大模型的推理。

f4687f7e-8e81-11ed-bfe3-dac502259ad0.png

LightSeq 在训练过程的量化中采用了真 int8 量化,也就是在矩阵乘法之前,会执行量化操作,并且在矩阵乘法之后才执行反量化操作。而不像过去的伪量化那样,在矩阵乘法之前就执行了量化和反量化操作,以让模型适应量化所带来的损失和波动。后者在实际计算中并不能带来加速,反而可能增大延时,或者使得显存占用上升。而真 int8 量化在实际应用中也带来了很好的加速效果。

2. 蒸馏

f487a548-8e81-11ed-bfe3-dac502259ad0.png

第二种模型压缩方式是蒸馏。蒸馏可以针对不同应用场景采用不同的策略对超大模型进行压缩,在某些情况下,蒸馏可以让超大模型拥有更好的泛化能力。

3. 剪枝

f4ac9e98-8e81-11ed-bfe3-dac502259ad0.png

最后一种模型压缩方案是剪枝。剪枝可分为全模型剪枝和部分层剪枝,对于超大模型,了解模型关键层非常重要,需要避开这些对精度影响最大的部分的剪枝,这对于稀疏 MoE 模型也是适用的。

4. 大模型工业化

大模型的研究和落地已成趋势,预计在 2022 年,关于大规模语言模型和 Transformers 的论文超过 1 万篇,比五年前 Transformers 刚提出的时候增长了 7 倍。另外,大模型也有非常广泛的应用,比如图片生成、推荐系统、机器翻译,甚至是生命科学、代码生成等。

f4d9c4cc-8e81-11ed-bfe3-dac502259ad0.png

OpenAI 也曾经在 2020 年发表过两篇论文,就展示过一个模型的表现基本上和三个主要的因素挂钩,即算力、数据集大小、模型参数量,以这三个指标就能很好地预测模型的效果。

f515aaf0-8e81-11ed-bfe3-dac502259ad0.png

Richard Sutton 曾经说过,在过去 70 年的 AI 发展中,一个反复出现的趋势是一个通用的能够高效利用计算资源的方法,总会是最后的赢家。

根据 Richard Sutton 的“赢家定律”,深度学习在过去近十年是赢在了通用性。

但如今,大模型训练的挑战已不言而喻。以 GPT-3 为例,其在训练的时候如果使用原始的混合精度,需要保存训练时的参数和梯度以及 FP 32 的主参数,如果使用 Adam 优化器,还要保存两个优化器的动量信息,则最终总共需要 2.8 个 TB 的显存,这远远超出了单卡的显存容量,需要超过 35 张 A100 才能承载。

NVIDIA 2021 年的论文“Efficient Large-Scale Language Model Training on GPU Clusters Using Megatron-LM”中得出一个经验公式,表明单次迭代参数量为 1750 亿的 GPT-3 模型就需要 4.5 亿 FLOPs 的算力。如果整个训练周期包含 95000 次迭代的话,就需要 430 ZettaFLOPs。换句话说,需要一块 A100 训练 16000 天,这还是不考虑计算效率的结论。

也就是说,光靠堆积这三个指标在大模型工业化时代将极大浪费资源。

DeepMind 在 2022 年发表的 ChinChilla 的论文中曾表示,实际上 GPT-3、OPT、PaLM 等大模型,基本都属于欠拟合模型。如果基于同样的计算资源,调小模型参数量,并训练更多步骤,最终的模型效果才能更好一些。这也是微信在 WeLM 大规模语言模型中遵循的设计思想。

业界各企业基本都在开始将注意力从规模上放松,转而关注大模型落地时的效率问题。

比如,从整体执行效率来看,经过 Megatron 优化的几乎所有模型都有 30% 的吞吐量提升,并且随着模型大小的增加,可以实现更高的 GPU 利用率。在 1750 亿参数的 GPT-3 模型上,GPU 利用率可以达到 52.8%。而在 5300 亿参数规模以上的模型上,利用率可以达到 57%。

也就是说,根据 Richard Sutton 的“赢家定律”,效率,将成为大模型工业化的主基调。


原文标题:大模型工业化的方法论,都藏在 GPU 里

文章出处:【微信公众号:NVIDIA英伟达】欢迎添加关注!文章转载请注明出处。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 英伟达
    +关注

    关注

    22

    文章

    3780

    浏览量

    91193
  • 大模型
    +关注

    关注

    2

    文章

    2476

    浏览量

    2794

原文标题:大模型工业化的方法论,都藏在 GPU 里

文章出处:【微信号:NVIDIA_China,微信公众号:NVIDIA英伟达】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    开源鸿蒙助力工业数字、赋能新型工业化

    鸿蒙助力工业数字、赋能新型工业化的经验和成果,并携手业界同仁共同推进武汉市开源体系建设。 拥抱开源鸿蒙,打造工业数字底座 工业操作系统是深
    的头像 发表于 12-19 11:36 243次阅读

    新型工业化物联网平台是什么

    新型工业化物联网平台,简而言之,是工业互联网平台的一种,它专为适应新型工业化发展需求而设计。这一平台将物联网技术与工业生产深度融合,通过全面感知、泛在互联、实时认知、精准调控等手段,实
    的头像 发表于 12-16 09:15 117次阅读

    材料失效分析方法汇总

    流程、减少成本以及提升市场竞争力扮演着至关重要的角色。失效分析的科学方法论失效分析的科学方法论是一套系统流程,它从识别失效模式着手,通过观察失效现象,逐步推导出
    的头像 发表于 12-03 12:17 290次阅读
    材料失效分析<b class='flag-5'>方法</b>汇总

    PyTorch GPU 加速训练模型方法

    在深度学习领域,GPU加速训练模型已经成为提高训练效率和缩短训练时间的重要手段。PyTorch作为一个流行的深度学习框架,提供了丰富的工具和方法来利用GPU进行
    的头像 发表于 11-05 17:43 573次阅读

    武汉数字孪生工业互联网可视技术,赋能新型工业化智能制造工厂

    武汉作为一座充满活力的超大城市,正以前所未有的速度推进数字孪生技术在工业互联网领域的应用,为新型工业化智能制造工厂注入强大动力。数字孪生技术作为工业互联网的核心组成部分,通过构建物理实体的高保真虚拟
    的头像 发表于 10-28 11:55 215次阅读

    华为云,调出AI原生三原色

    方法论、云基座与大模型,构成了AI原生时代的起点
    的头像 发表于 09-20 17:33 1854次阅读
    华为云,调出AI原生三原色

    天津港:码头与数智世界间的船票

    正确的方法论,是数智的起点与蓝图
    的头像 发表于 09-18 10:13 1289次阅读
    天津港:码头与数智世界间的船票

    爱立信吴日平:高性能可编程网络赋能新型工业化

    “新型工业化是我国产业升级的关键步骤,5G是为新型工业化提供无缝可靠连接的最优解。为了进一步发挥网络潜力、加快新型工业化发展,5G网络需要向高性能、可编程方向迈进。”
    的头像 发表于 05-20 18:27 1.9w次阅读

    工业模型赋能新型工业化的路径探索

    提供了深刻的理论支撑。当前,人工智能飞速发展,大语言模型(以下简称“大模型”)凭借强大的文本推理和迁移学习能力已成为人工智能发展新的里程碑,有望下沉到研发、生产、运维、测试等制造业各环节,实现对新型工业化的高
    的头像 发表于 05-07 10:36 430次阅读

    新型工业化塑造更强竞争力

    日前召开的国务院常务会议,研究加快推进新型工业化有关工作。工业化是现代的前提和基础。现阶段,我国工业化发展进入新的阶段,正面临数字转型和
    的头像 发表于 04-03 10:57 464次阅读

    “AI+工业互联网”赋能新型工业化的路径分析

    横看成岭侧成峰,探索“AI+工业互联网”技术赋能新型工业化的路径,还要从技术视角、产业视角、应用视角综合分析。
    的头像 发表于 03-14 10:57 1194次阅读

    工业智能网关助力推进新型工业化

    科学技术是第一生产力,新型工业化的突出特征便是工业化与信息的有机结合,不仅赋予生产要素、生产力和生产关系新的内涵和活力,而且促进各类产业主体优化生产布局、开展跨界合作、重构价值创造模式。
    的头像 发表于 02-05 15:41 382次阅读
    <b class='flag-5'>工业</b>智能网关助力推进新型<b class='flag-5'>工业化</b>

    元宇宙赋能新型工业化,推动工业制造业数字转型发展

    北京工业元宇宙赋能新型工业化,推动工业制造业数字转型发展。随着科技的不断进步,数字转型已经成为工业
    的头像 发表于 01-24 09:55 399次阅读

    工信部:加快推进新型工业化 推动人工智能创新应用

    近日,工业和信息部党组书记、部长金壮龙主持召开党组会议、党组理论学习中心组(扩大)学习会议。与会领导一致表示,要加快推进新型工业化,为中国式现代构筑强大物质技术基础。 会议强调,要
    的头像 发表于 01-10 09:56 593次阅读

    热点分享|新型工业化成为中国经济发展领域的高频热词

    工信部划重点:建设数字、智能、绿色的新型工业化,助力制造业转型升级! 在刚刚过去的2023年,“新型工业化”成为
    的头像 发表于 01-09 11:13 657次阅读
    热点分享|新型<b class='flag-5'>工业化</b>成为中国经济发展领域的高频热词