【GTC 22】PaiSparse:面向深度学习的稀疏算子库

本文涉及的产品
模型训练 PAI-DLC,100CU*H 3个月
交互式建模 PAI-DSW,每月250计算时 3个月
模型在线服务 PAI-EAS,A10/V100等 500元 1个月
简介: 随着越来越多超大语言模型的出现,如何将这些超大语言模型在实际业务中部署落地成为了一个急需解决的问题。这些超大语言模型拥有百亿千亿甚至于万亿的参数,如此巨大的参数使得无法将超大模型直接部署在单张卡上,而需要几个甚至几十个 GPU 参与模型推理,会消耗非常大的计算资源。然而一些常用的模型优化技术如剪枝和量化虽然能够有效的降低模型大小,但是这些算法却很难在保证精度的情况下达到较大的压缩率。因此我们选择了非结构化稀疏来压缩超大语言模型,从而使得他们能够在保证精度的情况下达到较高的压缩率。

研究动机


随着越来越多超大语言模型的出现,如何将这些超大语言模型在实际业务中部署落地成为了一个急需解决的问题。这些超大语言模型拥有百亿千亿甚至于万亿的参数,如此巨大的参数使得无法将超大模型直接部署在单张卡上,而需要几个甚至几十个 GPU 参与模型推理,会消耗非常大的计算资源。因此将超大语言模型进行部署的时候,就需要利用模型优化技术将它们进行压缩,从而减少模型参数量并提高推理速度。一些常用的模型优化技术如剪枝和量化虽然能够有效的降低模型大小,但是这些算法却很难在保证精度的情况下达到较大的压缩率。而对于超大语言模型而言,只有达到较高的压缩率,才有可能在单卡上部署起来。因此我们选择了非结构化稀疏来压缩超大语言模型,从而使得他们能够在保证精度的情况下达到较高的压缩率。


目前已有的稀疏算子库 CuSparse 虽然能够有效加速稀疏计算,但是我们发现神经网络训练出来的稀疏分布一般不是均匀的,而是呈现一定的分布特点(比如权重中一些行的稀疏率很高,一些行的稀疏率很低)。然而 CuSparse 是为了通用的高性能计算而开发出来的,一般而言均匀稀疏分布才能在 CuSparse 上得到较好的加速性能,而神经网络这样的分布特点无法在 CuSparse 上获得较好的加速效果。和高性能计算场景不一样的是,在神经网络推理中,我们可以预先根据权重的分布特点对最佳的稀疏算子实现进行搜索,从而生成针对当前权重稀疏分布更优的实现。


PaiSparse


PaiSparse 的设计思路如下图所示:

对于稀疏算子而言,主要可以分为三个计算阶段:

  1. Prolog Stage:从 gpu 内存中读取 CSR 格式的数据并存入寄存器中。
  2. Reduction Stage:负责进行稀疏计算。
  3. Epilog Stage:将计算结果存入 gpu 内存中。


我们预先在上述的三个计算阶段中定义了很多代码片段,并通过集成这些代码片段生成最终的稀疏算子。对于单个稀疏算子,我们的搜索空间包括 launch dim, index data type, thread group 和 reduction method 等。


其中,Index data type 的搜索空间包括 int 16和 int 32。int 16 可以有效减少内存读取的开销,但是会增加bit操作,如何进行选取会根据 weight 的具体分布来决定。Thread group 决定了有多少 thread 参与结果中一行的计算,这个参数可以使得算子的计算更加平衡。


除此之外,我们发现 reduction method 也是影响稀疏算子性能非常关键的一个因素,因此我们提出了四种 reduction method 并通过搜索决定最佳实现。这四种方法分别是:Register reduction,SHFL reduction,Shared memory reduction 和 Atomic reduction。针对一个特定的稀疏权重,我们需要首先计算需要执行多少次 register reduction,然后在此基础上计算执行多少次 SHFL reduction。接下来计算需要执行多少次 shared memory reduction,最后在执行完上述三种 reduction 后,剩余的数据累积到 atomic reduction。通过结合这4种 reduction method,PaiSparse 通过 nctrc 生成所有稀疏算子实现,并通过评估它们的性能决定最优实现。


实验结果


我们首先评估了 PLUG(Pre-training for Language Understanding and Generation)一个中文超大语言模型进行 99% 稀疏的精度结果。该模型拥有 270B 的参数量,通过 1TB以上的训练数据训练而成。



如上图所示,通过 99% 稀疏,PLUG 模型依然能够拥有相比于一些较小的语言模型更优的模型精度。


接下来,我们评估了在 99% 稀疏率下,PaiSparse 的稀疏算子性能。



首先在 SpMV 上,当 batch size=1 的时候,在 FP16 的数据格式上,PaiSparse 相比于CuBlas 有 2.7~22 倍的加速,相比于 CuSparse 有 1.22~1.91 倍的加速。在FP32的数据格式上,PaiSparse 相比于 CuBlas 有 27~37 倍的加速,相比于 CuSparse 有1.15~1.6 倍的加速。




在 SpMM 上,PaiSparse 相比于 CuSparse 拥有 1.8~4.9 倍的加速效果。




最后,比较 99% 稀疏下 PLUG 模型的性能。首先99%的稀疏可以在使用 4 张 GPU 进行推理的情况下,将显存占用从13.5GB 降低到 1.8GB,极大的减少了模型的显存占用,同时相比于原始 PLUG 模型至少需要4张V100进行推理的情况,稀疏后的 PLUG 可以部署在单张 V100 上,减少了部署的成本。比较整个 PLUG 网络端到端的推理速度,集成了 PaiSparse的稀疏网络相比于原始 Dense 网络可以达到 1.6 倍的加速。


总结


稀疏可以在保证模型精度的情况下,有效减少大模型需要的计算资源。我们提出的PaiSparse 通过分析深度学习里权重稀疏分布的特点,实现了搜索稀疏算子的整套方案,从而可以针对具体的稀疏分布生成的最优的稀疏算子实现,达到更好的计算性能。


相关实践学习
使用PAI-EAS一键部署ChatGLM及LangChain应用
本场景中主要介绍如何使用模型在线服务(PAI-EAS)部署ChatGLM的AI-Web应用以及启动WebUI进行模型推理,并通过LangChain集成自己的业务数据。
机器学习概览及常见算法
机器学习(Machine Learning, ML)是人工智能的核心,专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能,它是使计算机具有智能的根本途径,其应用遍及人工智能的各个领域。 本课程将带你入门机器学习,掌握机器学习的概念和常用的算法。
相关文章
|
5月前
|
机器学习/深度学习 计算机视觉 Python
深度学习项目中在yaml文件中定义配置,以及使用的python的PyYAML库包读取解析yaml配置文件
深度学习项目中在yaml文件中定义配置,以及使用的python的PyYAML库包读取解析yaml配置文件
202 0
|
6月前
|
机器学习/深度学习 PyTorch TensorFlow
在深度学习中,数据增强是一种常用的技术,用于通过增加训练数据的多样性来提高模型的泛化能力。`albumentations`是一个强大的Python库,用于图像增强,支持多种图像变换操作,并且可以与深度学习框架(如PyTorch、TensorFlow等)无缝集成。
在深度学习中,数据增强是一种常用的技术,用于通过增加训练数据的多样性来提高模型的泛化能力。`albumentations`是一个强大的Python库,用于图像增强,支持多种图像变换操作,并且可以与深度学习框架(如PyTorch、TensorFlow等)无缝集成。
|
8月前
|
机器学习/深度学习 数据可视化 Python
如何使用Python的PyBrain库进行深度学习
【4月更文挑战第22天】PyBrain是Python深度学习库,用于构建和训练模型。步骤包括安装库、导入模块、准备数据集、创建网络、训练、预测、评估和可视化。示例代码展示了如何使用PyBrain处理线性数据,包括网络构建、训练、误差计算和结果可视化。
58 3
|
8月前
|
机器学习/深度学习 数据采集 数据可视化
如何使用Python的PyBrain库进行深度学习?
PyBrain是Python的深度学习库,用于构建和训练模型。步骤包括安装库、导入模块、准备数据集、创建网络、训练、预测、评估和可视化。示例代码展示了如何使用PyBrain处理线性数据,包括数据预处理、构建2-3-1网络、BackpropTrainer训练、计算MSE误差和结果可视化。
143 0
|
8月前
|
机器学习/深度学习 TensorFlow 算法框架/工具
【深度学习】Tensorflow、MindSpore框架介绍及张量算子操作实战(超详细 附源码)
【深度学习】Tensorflow、MindSpore框架介绍及张量算子操作实战(超详细 附源码)
241 0
|
机器学习/深度学习 Java 算法框架/工具
Java深度学习库DJL实现Python的NumPy
Java深度学习库DJL实现Python的NumPy
672 1
|
机器学习/深度学习 编解码 算法
深度学习基础入门篇[9.3]:卷积算子:空洞卷积、分组卷积、可分离卷积、可变性卷积等详细讲解以及应用场景和应用实例剖析
深度学习基础入门篇[9.3]:卷积算子:空洞卷积、分组卷积、可分离卷积、可变性卷积等详细讲解以及应用场景和应用实例剖析
深度学习基础入门篇[9.3]:卷积算子:空洞卷积、分组卷积、可分离卷积、可变性卷积等详细讲解以及应用场景和应用实例剖析
|
机器学习/深度学习 存储 编解码
深度学习基础入门篇[9.3]:卷积算子:空洞卷积、分组卷积、可分离卷积、可变性卷积等详细讲解以及应用场景和应用实例剖析
深度学习基础入门篇[9.3]:卷积算子:空洞卷积、分组卷积、可分离卷积、可变性卷积等详细讲解以及应用场景和应用实例剖析
220 0
|
机器学习/深度学习 PyTorch 算法框架/工具
Pytorch贝叶斯深度学习库BLiTZ实现LSTM预测时序数据(二)
Pytorch贝叶斯深度学习库BLiTZ实现LSTM预测时序数据(二)
723 0
Pytorch贝叶斯深度学习库BLiTZ实现LSTM预测时序数据(二)
|
机器学习/深度学习 数据采集 PyTorch
Pytorch贝叶斯深度学习库BLiTZ实现LSTM预测时序数据(一)
Pytorch贝叶斯深度学习库BLiTZ实现LSTM预测时序数据(一)
582 1
Pytorch贝叶斯深度学习库BLiTZ实现LSTM预测时序数据(一)