Janus: Data-Centric MoE 通讯成本分析(2)

2023-10-24 02:52

本文主要是介绍Janus: Data-Centric MoE 通讯成本分析(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章链接:Janus: A Unified Distributed Training Framework for Sparse Mixture-of-Experts Models

发表会议: ACM SIGCOMM 2023 (计算机网络顶会)

系统学习:Janus: 逆向思维,以数据为中心的MoE训练范式(1)

目录

  • 前言
  • 通讯成本分析
    • 1. Expert Parallelism and all-to-all
    • 2. Traffic Comparison between D-C. and E-C.
    • 3. Communication Efficiency Analysis
      • A. Forward Phase
      • B. Backward Phase
      • C. Ratio measure
  • Be Janus

前言

在之前的blog中,我们学习了Janus的理论基础和模型搭建。基于专家的规模小于数据规模的假设,作者得到了Data-Centric的思想灵感,并验证了算法的有效性。
通过Data-Centric这一范式思路和巧妙的读取测略,Janus极大的减少了算法的通讯成本。这篇blog将从数学的角度定量解读Janus是如何降低通讯开销的。

通讯成本分析

1. Expert Parallelism and all-to-all

在这里插入图片描述
一个MoE模型的尺寸可能会大到超过单个gpu的能力。为了在gpu上训练一个大规模的MoE模型,专家并行(Expert Parallelism,EP)被提出并得到广泛应用。

右图显示了EP的概念。专家并行是将专家层划分为几个部分,并分配给GPU。每个GPU中都有专家层的专家,不同的GPU中有不同的专家。对于MoE模型的其他部分(如attention layer和Gate),每个GPU持有一个独立的副本

在这里插入图片描述
目前EP的实现默认是以专家为中心的。图(a)说明了以专家为中心的训练过程。当MoE块处理token序列时,gate需要为每个token分配专家,而token由gate分发到承载分配专家的gpu。

这种token到gpu的分发是由一个all-to-all通信原语完成的,因为由gpu生成的令牌的目标gpu很可能包括所有的gpu。token被指定的专家处理后,需要将结果发送回其原始的gpu,这需要再次进行all-to-all通信。由于MoE模型通常具有多个MoE块,因此MoE模型的训练可能涉及到多次的all-to-all通信操作。


2. Traffic Comparison between D-C. and E-C.

模型
参数
MoE-BertMoE-GPTMoE-Transformer-xl
Batch size B B B25625664
Seq-lenth S S S12864512
Top-K in Gate242
Expert dim. H H H768768256
MoE Block4112
Total block121212
Expert num16    3216    3216    32
GPU num16    3216    3216    32
Model Size(B)0.42   0.730.23   0.310.11   0.21
E-C. Traffic(GB)6   91.5   2.256   9
D-C. Traffic(GB)0.56   1.690.14   0.420.19   0.56

上表展示了以专家为中心的范式(E-C.)和数据中心范式(D-C.)的模型配置和通讯成本大小。
可以看到,在相同的模型配置下,D-C.的通讯量明显低于E-C.


3. Communication Efficiency Analysis

由于整个系统的通信瓶颈在于节点间通信而非节点内通信,故将节点间通信量作为衡量训练系统潜在通信效率的指标。

记号含义
n n n设备数量
m m m每个设备的工作进程
E E E每个工作进程的专家数量
H H H向专家输入的token的维度
T T T工作进程生成的token数
k k k门参数 top-K
B B B每个工作进程的训练任务的批量大小
S S S训练任务的序列长度

A. Forward Phase

在MoE模型中,每个Expert通常是一个由两个线性层组成的前馈网络(FFN)。对于一个FFN模块,第一层包括一个形状为 H ∗ 4 H H*4H H4H 的矩阵,第二层包括一个形状为 4 H ∗ H 4H*H 4HH 的矩阵。因此,一个FFN模块的大小为 8 H 2 8H^{2} 8H2

每个工作进程都有专家,每台设备就有专家。由于每台设备都需要将这些专家广播给其他 n − 1 n−1 n1 台设备,因此在MoE块的训练过程中,D-C.的通讯量为:
C o m m D C = 8 H 2 E m ( n − 1 ) Comm_{DC}=8H^{2}Em(n-1) CommDC=8H2Em(n1)

E-C.的训练系统中,专家之间的token分配通常是不平衡的。完成通信所需的时间取决于发送/接收数据量最大的设备。显然,非平衡分布下的通信时间几乎总是比平衡分布下的通信时间长

现在计算E-C.的训练系统中要传输的token大小,即节点间通信量。每个工作进程生成token,然后一个 m-worker (GPU)设备可以生成 m T mT mT 个token。

在token均衡分配的假设下,token被发送到其他设备的百分比为 n − 1 n \frac{n-1}{n} nn1。在E-C.中,MoE型块需要在前向计算阶段执行all-to-all通信操作。因此,MoE块中以E-C.的通信量为:
C o m m E C = 2 m H T ⋅ n − 1 n Comm_{EC}=2mHT\cdot \frac{n-1}{n} CommEC=2mHTnn1


B. Backward Phase

对于后向阶段,在E-C.中,系统需要传输生成梯度所需的所有中间结果,并且这个量等于它在前向阶段中发送的token的量

D-C.中,系统可以重用在前向阶段提取和缓存的专家。在专家模块计算出梯度后,梯度应该被发送回原始工作进程。梯度的大小与拉取的专家模型相同,通信方向相反。

此外,同一个专家在一台设备上的多个梯度被减少和合并,然后被送回。因此,在D-C.中,后向阶段中的通讯量也等于前向阶段中的通讯量


C. Ratio measure

在分析了两种模式的通讯量后,文章定义了一个度量 R R R 来评估 D-C. 的理论增益,它是两种范式下节点间通信量的比率:
R = C o m m E C C o m m D C = T 4 n H E R=\frac{Comm_{EC}}{Comm_{DC}}=\frac{T}{4nHE} R=CommDCCommEC=4nHET

给定训练参数可以计算出token的数量 T T T,包括批大小 B B B、序列长度 S S S 以及与相关的Gate参数 top-K: k k k T = B S k T=BSk T=BSk 于是有:
R = C o m m E C C o m m D C = B S k 4 n H E R=\frac{Comm_{EC}}{Comm_{DC}}=\frac{BSk}{4nHE} R=CommDCCommEC=4nHEBSk

R > 1 R>1 R>1 表明D-C.效率优于E-C.效率。


Be Janus

Janus是一个以专家为中心的范式和以数据为中心的范式的统一框架。Janus在混合专家模型模型的训练开始前进行评估。

对于其中 R ≤ 1 R\le 1 R1 的MoE块,Janus默认使用专家中心范式。
对于其中 R ≥ 1 R\ge 1 R1 的MoE块,Janus将使用以数据为中心的范式。

这篇关于Janus: Data-Centric MoE 通讯成本分析(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/272252

相关文章

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

找不到Anaconda prompt终端的原因分析及解决方案

《找不到Anacondaprompt终端的原因分析及解决方案》因为anaconda还没有初始化,在安装anaconda的过程中,有一行是否要添加anaconda到菜单目录中,由于没有勾选,导致没有菜... 目录问题原因问http://www.chinasem.cn题解决安装了 Anaconda 却找不到 An

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

Spring、Spring Boot、Spring Cloud 的区别与联系分析

《Spring、SpringBoot、SpringCloud的区别与联系分析》Spring、SpringBoot和SpringCloud是Java开发中常用的框架,分别针对企业级应用开发、快速开... 目录1. Spring 框架2. Spring Boot3. Spring Cloud总结1. Sprin

Spring 中 BeanFactoryPostProcessor 的作用和示例源码分析

《Spring中BeanFactoryPostProcessor的作用和示例源码分析》Spring的BeanFactoryPostProcessor是容器初始化的扩展接口,允许在Bean实例化前... 目录一、概览1. 核心定位2. 核心功能详解3. 关键特性二、Spring 内置的 BeanFactory

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景