把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

利用cpu和gpu协同计算,显著提升大语言模型推理效率!来自cmu、华盛顿大学和meta ai的研究人员提出了一种名为magicpig的新方法,它巧妙地利用cpu上的局部敏感哈希(lsh)技术,有效缓解了gpu内存容量限制,从而大幅提升大语言模型(llm)的推理速度和准确性。

与仅依赖GPU的注意力机制相比,MagicPIG在解码吞吐量方面实现了1.76到4.99倍的提升,并在多个下游任务中取得了优于现有技术(例如Quest)的准确率。

这项研究的主要贡献在于:

突破性精度提升: 不同于其他稀疏注意力机制,MagicPIG基于采样和估计而非搜索,从而在保证推理质量的前提下,显著提高效率。

高效异构计算: 将解码阶段的注意力计算和哈希表操作卸载到CPU,充分利用异构计算架构,提高吞吐量并降低模型部署成本。

GPU内存瓶颈:KV缓存的挑战

在LLM推理中,KV缓存是主要的性能瓶颈。 KV缓存存储中间注意力键值对,避免重复计算。然而,其内存占用随着批量大小和序列长度线性增长,严重限制了GPU的批量处理能力,导致GPU利用率低下。例如,在NVIDIA A100-40GB GPU上处理Llama-3.1-8B模型(上下文长度128k)时,只能处理单个请求,且近一半的解码时间都耗费在KV缓存访问上。多样性生成和长链式推理等技术进一步加剧了这一问题。

TopK注意力机制的局限性

注意力机制本身具有稀疏性,因此动态稀疏注意力和TopK近似方法被广泛研究。但这些方法通常会造成精度下降。现有技术如Quest、H2O和Loki主要通过选择注意力得分最高的键值对来提高效率,但这种基于TopK的近似方法存在偏差,缺乏理论保障,尤其在高精度要求的任务(如聚合任务、常用词提取、高频词提取和逻辑推理)中表现不佳。

下图显示了TopK注意力机制的估计误差和性能下降:

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

研究人员通过观察发现,TopK方法的失效与以下现象有关:

首个输入token的隐藏状态几乎不随输入变化。键状态的中心方向在不同输入句子中保持稳定。键状态的中心与汇聚点token的键状态几乎相反。

下图展示了这些观察结果:

把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

MagicPIG:基于采样的注意力估计

为了解决TopK方法的局限性,MagicPIG提出了一种基于采样的注意力估计方法。 该方法将问题视为偏差校正问题,利用局部敏感哈希(LSH)技术生成采样概率,并通过重要性采样来估计注意力输出。 与TopK方法相比,这种基于采样的方法显著降低了估计误差。

文心大模型 文心大模型

百度飞桨-文心大模型 ERNIE 3.0 文本理解与创作

文心大模型 56 查看详情 文心大模型

下图对比了基于采样的方法和TopK方法的估计误差:

把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

系统设计:CPU-GPU协同工作

MagicPIG将注意力计算和哈希表操作卸载到CPU,充分利用CPU的内存优势。 研究人员发现,通过采样技术降低内存访问量,可以有效弥补CPU内存带宽低于GPU的不足。 系统将LLM解码分为四个部分:参数计算(GPU)、注意力计算(CPU)、随机投影(GPU)和检索(CPU)。

下图展示了MagicPIG的系统架构:

把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

实验结果

实验结果表明,MagicPIG在长文本RULER任务中取得了比Quest更高的准确率,并且在推理速度和吞吐量方面有显著提升。

下图展示了MagicPIG在长文本RULER任务中的准确率:

把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

下图展示了MagicPIG的吞吐量提升:

把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍

总结:MagicPIG 通过巧妙地结合采样技术和异构计算,为高效的LLM推理提供了一种新的思路,有望降低LLM的部署成本并推动其更广泛的应用。

以上就是把注意力计算丢给CPU,大模型解码吞吐量提高1.76~4.99倍的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/375945.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 09:40:37
下一篇 2025年11月6日 09:42:03

相关推荐

  • RSS订阅中的作者信息格式

    RSS和Atom中作者信息通过或标签标识,包含姓名、邮箱及网站链接,支持多作者;正确设置有助于提升内容可信度、便于追踪与SEO。 RSS订阅中的作者信息格式,主要用于标识文章的作者,让读者知道是谁写的,方便追踪特定作者的内容。格式通常包含作者姓名、邮箱,有时还会包含作者的网站链接。 作者信息的常见格…

    2025年12月17日
    000
  • XML中如何解压XML字符串_XML解压XML字符串的操作方法

    先解压再解析XML。C#用GZipStream解压字节流并转字符串,Java用GZIPInputStream或InflaterInputStream读取压缩数据,结合StreamReader或BufferedReader还原为明文XML后,交由XDocument或DocumentBuilder解析;…

    2025年12月17日
    000
  • XML中如何判断节点是否存在_XML判断节点存在性的技巧与方法

    使用XPath或find方法判断XML节点是否存在,若返回结果为空则节点不存在,结合attrib检查属性,并区分节点存在与文本内容是否为空。 在处理XML文档时,判断某个节点是否存在是一个常见需求。无论是解析配置文件、处理接口返回数据,还是进行数据校验,准确判断节点是否存在可以避免程序出错。以下是几…

    2025年12月17日
    000
  • XML中如何检查节点顺序_XML检查节点顺序的方法与技巧

    使用XPath、DOM解析、XSD约束和断言工具可检查XML节点顺序。首先通过XPath的position()函数验证节点位置,如//data/item[@type=’A’ and position()=1];其次用Python等语言解析DOM并比对实际与预期顺序;再者利用X…

    2025年12月17日
    000
  • RSS源如何实现内容推荐

    要实现RSS%ignore_a_1%,需在RSS数据基础上构建智能推荐系统。首先通过feedparser等工具抓取并解析RSS内容,提取标题、摘要、发布时间等信息,并存储到数据库中;对于仅提供片段的源,可结合Web Scraping技术获取全文。随后利用NLP技术对内容进行处理,包括分词、去停用词、…

    2025年12月17日
    000
  • 什么是OpenTravel标准

    OpenTravel标准是旅游行业通用的XML消息格式,由OpenTravel Alliance维护,通过定义如OTA_AirAvailRQ/RS等消息类型,实现航空公司、酒店、旅行社等系统间的数据互通;它简化集成、降低成本,并支持自动化预订与查询;尽管JSON在轻量性和解析速度上占优,但OpenT…

    2025年12月17日
    000
  • XML中如何修改节点值_XML修改节点值的实用方法与注意事项

    使用DOM、XPath或流式处理可修改XML节点值,推荐小文件用DOM+XPath、大文件用流式处理,注意编码、空节点、格式保留及备份验证。 在处理XML数据时,修改节点值是一个常见需求。无论是配置文件更新、数据转换,还是接口报文调整,掌握正确的方法至关重要。下面介绍几种实用的XML节点值修改方式,…

    2025年12月17日
    000
  • XML中如何判断节点类型_XML判断节点类型的方法与步骤

    XML节点类型包括元素、文本、属性、注释和文档节点,正确识别可精准提取或修改数据;2. Python使用xml.dom.minidom通过node.nodeType判断,如ELEMENT_NODE=1、TEXT_NODE=3;3. JavaScript中用DOM的node.nodeType,值为1是…

    2025年12月17日
    000
  • XML中如何处理空值_XML处理XML空值的技巧与方法

    使用xsi:nil=”true”显式表示XML空值,需声明命名空间并确保Schema允许;区分空字符串与缺失元素的语义差异;解析时通过DOM、SAX或XPath设置默认值;Schema设计中合理配置minOccurs和nillable属性以预防问题;关键在于各环节统一处理策略…

    2025年12月17日
    000
  • XML与JSON有何区别?如何选择?

    XML结构复杂支持属性和命名空间,适合复杂数据与行业标准;JSON语法简洁体积小,解析高效,适用于Web接口与前后端交互,现代应用多选JSON,传统系统或特定领域仍用XML。 XML和JSON都是数据交换的格式,但它们在结构、语法和使用场景上有明显不同。选择哪种取决于具体需求,比如数据复杂度、可读性…

    2025年12月17日
    000
  • XML解析是什么意思?有哪些解析方法?

    DOM解析将整个XML文档加载进内存构建树形结构,适合中小型文件的频繁操作;2. SAX采用事件驱动流式解析,内存占用小,适用于大文件一次性读取;3. StAX提供拉模式流式读取,兼顾效率与控制,适合需高效处理且有主动控制需求的场景;4. PULL解析用于Android平台,编程简单,适合移动设备上…

    2025年12月17日
    000
  • 如何转换XML到数据库表

    答案:XML转数据库需分析结构、设计表、选择解析技术并处理数据类型与性能。首先解析XML层次结构,映射实体为表,属性为列,嵌套元素转子表;选用DOM或SAX等工具,结合Python、Java等语言实现ETL;注意数据类型转换、缺失值、主键设计及范式权衡;面对大文件用流式解析与批量插入优化性能,确保事…

    2025年12月17日
    000
  • XML在智能家居中的应用

    XML在智能家居中提供统一的数据结构,实现设备间互联互通。其树状标签结构支持设备配置、状态汇报与服务描述,确保多品牌设备协同工作。相比JSON,XML具备更强的Schema验证、命名空间支持和元数据能力,提升系统健壮性与可维护性,但存在文件冗余、解析复杂等挑战。实际应用中,XML常用于设备注册、状态…

    2025年12月17日
    000
  • XML中如何创建XML模板_XML创建XML模板的操作步骤

    明确数据结构和用途,确定节点、层级及是否需要命名空间;2. 编写基础XML结构,用占位符标记可变内容;3. 可选添加命名空间、属性或DTD/Schema声明;4. 保存为模板文件并通过程序替换占位符复用。 在XML中创建模板,其实是指设计一个结构清晰、可复用的XML文件框架,用于后续填充数据或作为其…

    2025年12月17日
    000
  • XML中如何合并节点属性_XML合并节点属性的方法与技巧

    合并XML节点属性需基于唯一标识识别目标节点,通过编程语言(如Python)或XSLT实现属性整合。1. 使用Python的ElementTree解析XML,遍历属性并根据策略(如允许覆盖)合并;2. 利用XSLT模板匹配同名节点,复制源属性并筛选不冲突的目标属性;3. 注意处理属性冲突、确保节点唯…

    2025年12月17日
    000
  • 什么是XMDP?如何定义元数据

    XMDP是一种元数据定义的元语言,通过XML文件规范微格式中class和rel属性的语义,为HTML提供机器可读的“字典”,提升网页语义化与数据互操作性;其核心在于定义“如何定义数据”,虽在现代Web中被Schema.org等主流标准取代,但其思想对理解语义Web演进仍具价值。 XMDP,全称Ext…

    2025年12月17日
    000
  • 如何实现XML数据脱敏

    XML数据脱敏需先识别敏感信息,再结合业务需求选择替换、掩码、删除或加密等策略,利用XPath精准定位,并通过DOM、SAX或XSLT技术实现,同时兼顾结构复杂性、性能、数据一致性与合规性要求。 实现XML数据脱敏,核心在于精准识别XML文档中的敏感信息,并根据业务需求和合规性要求,运用合适的脱敏策…

    2025年12月17日
    000
  • XML Schema有何作用?如何定义XSD文件?

    XML Schema用于定义XML文档结构、元素、属性及数据类型,支持命名空间和复杂约束,通过XSD文件实现数据校验与规范。 XML Schema(XML 模式)用于定义 XML 文档的结构、元素、属性及其数据类型,确保 XML 内容符合预设规则。相比 DTD,XML Schema 支持数据类型、命…

    2025年12月17日
    000
  • XML格式的电子邮件如何?SMTP协议支持吗?

    可以。邮件内容可以是XML,通过设置正确的MIME类型或将XML作为附件发送,SMTP负责传输,解析依赖客户端和接收方处理逻辑。 XML格式的电子邮件可以发送,但SMTP协议本身并不关心邮件内容是否为XML。SMTP(Simple Mail Transfer Protocol)只负责传输邮件,不解析…

    2025年12月17日
    000
  • XML与化学标记语言CML是什么?如何表示分子?

    CML是基于XML的化学标记语言,由Peter Murray-Rust等人开发,用于机器可读地表示分子结构、反应和光谱等化学信息;它通过、、等标签定义化学实体,如水分子可用原子坐标和键连接关系精确描述;相比SMILES,CML在复杂数据交换、数据库存储和软件兼容方面具有优势,被广泛应用于化学信息学领…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信