不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

开源社区的一位开发者Georgi Gerganov发现,自己可以在M2 Ultra上运行全F16精度的34B Code Llama模型,而且推理速度超过了20 token/s。

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

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

M2 Ultra的带宽达到了800GB/s,这在其他人通常需要使用4个高端GPU才能实现的情况下

而这背后真正的答案是:投机采样(Speculative Sampling)。

乔治的发现立刻引发了人工智能界大佬们的讨论

Karpathy转发评论道,「LLM的投机执行是一种出色的推理时间优化」。

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

「投机采样」加速推理

在这个例子中,Georgi借助Q4 7B quantum草稿模型(也就是Code Llama 7B)进行了投机解码,然后在M2 Ultra上使用Code Llama34B进行生成。

简单讲,就是用一个「小模型」做草稿,然后用「大模型」来检查修正,以此加速整个过程。

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

github地址:https://twitter.com/ggerganov/status/1697262700165013689

根据Georgi的介绍,这些模型的速度分别如下:

F16 34B:每秒约10个令牌

需要进行改写的内容是:Q4 7B:每秒约80个令牌

以下是一个没有使用投机采样的标准F16采样示例:

在加入投机采样策略之后,速度可以达到每秒约20个标记

根据Georgi的说法,生成内容的速度可能会有所不同。然而,这种方法在代码生成方面似乎非常有效,因为大多数词库都能被草稿模型正确猜测

使用「语法采样」的用例也有可能从中受益匪浅

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

投机采样是如何实现快速推理的?

Karpathy根据此前谷歌大脑、UC伯克利、DeepMind的三项研究,做出了解释。

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

请点击以下链接查看论文:https://arxiv.org/pdf/2211.17192.pdf

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

论文地址:https://arxiv.org/pdf/1811.03115.pdf

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

论文地址:https://arxiv.org/pdf/2302.01318.pdf

Llama Coder Llama Coder

Llama Coder 是一个AI驱动的代码生成工具,可以一键生成完整的应用程序

Llama Coder 123 查看详情 Llama Coder

这取决于以下不直观的观察结果:

在单个输入token上转发LLM所需的时间,与在K个输入token上批量转发LLM所需的时间相同(K比你想象的要大)。

这个不直观的事实是因为采样受到内存的严重限制,大部分「工作」不计算,而是将Transformer的权重从VRAM读取到芯片上缓存中进行处理。

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

为了完成读取所有权重的任务,最好将它们应用于整个批量的输入向量

我们之所以不能天真地利用这一事实,来一次采样K个token,是因为每N个token都取决于,我们在第N-1步时采样的token。这是一种串行依赖关系,因此基线实现只是从左到右逐个进行。

现在,一个巧妙的想法是使用一个小而廉价的草稿模型,首先生成一个由K个标记组成的候选序列——「草稿」。然后,我们将所有这些信息一起批量送入大模型

根据上述方法,这与只输入一个token的速度几乎一样快。

然后,我们从左到右检查模型,以及样本token预测的logits。任何与草稿一致的样本都允许我们立即跳转到下一个token。

如果存在分歧,我们将放弃草稿模型,并承担进行一些一次性工作的成本(对草稿模型进行采样,并对后续的标记进行前向传递)

这在实践中行之有效的原因是,大多数情况下,draft token都会被接受,因为是简单的token,所以即使是更小的草稿模型也能接受它们。

当这些简单的token被接受时,我们就会跳过这些部分。大模型不同意的困难token会「回落」到原始速度,但实际上因为有额外的工作会慢一些。

所以,总而言之:这一怪招之所以管用,是因为LLM在推理时是受内存限制。在「批大小为1」的情况下,对感兴趣的单个序列进行采样,而大部分「本地 LLM」用例都属于这种情况。而且,大多数token都很「简单」。

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

HuggingFace的联合创始人表示,340亿参数的模型在一年半以前的数据中心之外,看起来非常庞大和难以管理。现在只需使用笔记本电脑就可以轻松处理了

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

现在的LLM并不是单点突破,而是需要多个重要组件有效协同工作的系统。投机解码就是一个很好的例子,可以帮助我们从系统的角度进行思考。

不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手

以上就是不用4个H100!340亿参数Code Llama在Mac可跑,每秒20个token,代码生成最拿手的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 17:25:01
下一篇 2025年11月8日 17:26:42

相关推荐

  • groupcache分布式缓存的Peer通信与HTTPPool使用指南

    groupcache通过http协议实现其分布式缓存节点的通信。httppool是groupcache官方实现中唯一内置的对等节点(peer)通信管理机制,负责将请求路由到正确的缓存节点。本文将详细介绍groupcache如何利用httppool构建可伸缩的分布式缓存集群,并提供具体的配置和使用示例…

    2025年12月16日
    000
  • Go语言日志文件输出:使用os.OpenFile实现高效持久化

    本教程详细介绍了在Go语言中如何正确地将日志写入文件。核心在于使用`os.OpenFile`函数,而非`os.Open`,并结合`os.O_RDWR`、`os.O_CREATE`和`os.O_APPEND`等文件操作模式,确保文件能够被创建、读写并支持追加写入。文章提供了清晰的代码示例,并解释了关键…

    2025年12月16日
    000
  • Go语言中将MySQL数据高效转换为JSON的实用指南

    本文旨在提供一个在go语言中将mysql数据库表数据高效转换为json格式的教程。我们将探讨在处理数据库扫描结果时,如何避免所有数据类型都被识别为字节数组(`[]byte`)的问题,并通过动态类型检查和适当的数据转换,确保数值、布尔值等原始类型在json中得到正确表示,从而生成符合预期的json输出…

    2025年12月16日
    000
  • Golang如何实现Kubernetes CronJob任务调度

    Go语言通过client-go与Kubernetes API交互实现CronJob调度,核心是构造符合batch/v1规范的CronJob资源对象并调用Create方法提交至API Server,或使用Informer监听事件实现自定义控制器逻辑。 Go语言实现Kubernetes CronJob任…

    2025年12月16日
    000
  • Go语言中HTTP Cookie的正确获取与处理

    在go语言的web开发中,正确获取和处理http cookie是常见的需求。本教程将深入探讨使用`net/http`包获取cookie时可能遇到的变量作用域、类型处理及错误处理等常见问题,并提供一个健壮的解决方案,确保开发者能够高效、准确地在go应用中管理cookie数据。 理解Go中HTTP Co…

    2025年12月16日
    000
  • 使用Go语言设计对象工厂模式:利用接口实现多态创建

    在Go语言中,实现一个能够根据输入创建不同类型对象的“对象工厂”模式,关键在于利用接口实现多态性。本文将详细介绍如何通过定义共享行为的接口,让不同的结构体实现该接口,并使工厂函数返回该接口类型,从而克服Go语言中没有传统继承的限制,优雅地构建灵活且可扩展的对象创建机制。 理解Go语言中的类型系统与多…

    2025年12月16日
    000
  • Go语言中基于Channel的快速排序:并发实现、机制解析与性能考量

    本文深入探讨Go语言中基于Channel实现的快速排序算法。我们将解析其并发机制,理解数据如何通过Channel在Goroutine间流动,并评估这种实现方式的实际性能。虽然Channel提供了优雅的并发数据流解决方案,但对于快速排序这类算法,其并发开销可能导致性能不如传统非并发实现,尤其在资源消耗…

    2025年12月16日
    000
  • Go语言测试包命名策略:深度解析白盒与黑盒测试实践

    本文深入探讨go语言中测试包的命名策略,主要围绕`package myfunc`和`package myfunc_test`两种模式展开。我们将分析每种策略的优缺点,以及它们如何影响测试的类型(白盒测试或黑盒测试)。通过对比不同方法,帮助开发者理解何时选择内部包测试以访问私有成员,何时选择外部包测试…

    2025年12月16日
    000
  • Go语言中HTTP Cookie的正确获取与处理实践

    本文详细介绍了在go语言web应用中如何正确获取和处理http cookie。重点探讨了变量作用域、类型匹配以及错误处理机制,通过示例代码演示了避免常见undefined变量错误和类型转换问题的最佳实践,确保开发者能够稳定、可靠地在web服务中操作cookie数据。 在Web开发中,Cookie是客…

    2025年12月16日
    000
  • Go语言中实现对象工厂模式:利用接口构建灵活的类型创建机制

    在go语言中,由于其独特的类型系统和缺乏传统意义上的类继承,直接实现多态对象工厂可能面临挑战。本文将深入探讨如何利用go的接口(interface)机制,设计并实现一个能够根据输入动态创建不同类型对象的工厂函数。我们将通过具体代码示例,展示如何定义通用接口,并使不同结构体类型满足该接口,从而构建一个…

    2025年12月16日
    000
  • Golang如何在Linux上配置开发工具链

    安装Go环境并配置PATH,设置GOPATH和GOBIN,启用Go Modules,选择VS Code并安装Go扩展与工具,创建项目测试运行与构建,确保权限正确即可完成Linux下Golang开发环境搭建。 在Linux上配置Golang开发工具链并不复杂,只要按步骤安装Go环境并设置好相关路径,再…

    2025年12月16日
    000
  • Go database/sql:深度解析预处理语句与直接查询的机制与实践

    go 语言 `database/sql` 包为数据库操作提供了通用接口。本文深入探讨了预处理语句与直接查询在 go 中的实现机制,阐明了驱动在参数化处理中的核心作用。我们将解释为何 `query/queryrow` 也能安全接受参数,并分析预处理语句在防范 sql 注入、提升重复查询性能方面的独特优…

    2025年12月16日
    000
  • 构建可扩展的 groupcache:对等节点通信与 HTTPPool 详解

    groupcache通过http协议实现对等节点间的通信,其核心组件是httppool。本文将深入探讨groupcache对等节点如何利用httppool进行数据共享与协调,解释其在构建可扩展缓存系统中的关键作用,并提供详细的httppool配置与使用示例,帮助读者理解并实践groupcache的分…

    2025年12月16日
    000
  • Go语言中对结构体Map进行排序的有效方法

    go语言中的`map`类型是无序的,因此无法直接对其进行排序。要实现对存储结构体的`map`按特定字段排序,核心策略是将其值提取到一个结构体指针切片中。通过为该切片类型实现`sort.interface`接口的`len`、`swap`和`less`方法,然后调用`sort.sort`函数,即可对数据…

    2025年12月16日
    000
  • Go语言错误处理深度解析:区分 error 与 panic

    本文深入探讨Go语言中错误处理的两种主要机制:`error`类型和`panic`/`recover`。文章详细阐述了它们的设计哲学、适用场景及具体实现方式。通过代码示例,清晰展示了如何使用`error`处理可预期的操作失败,以及如何利用`panic`和`recover`应对程序中的非预期、致命性错误…

    2025年12月16日
    000
  • Go语言并发编程:动态监听N个Channel的实现策略

    本文将深入探讨go语言中如何实现对数量可变的n个channel进行动态监听。当go的`select`语句无法满足动态场景需求时,我们可以借助`reflect`包中的`select`函数。教程将详细介绍`reflect.select`的工作原理、`selectcase`的构造,并提供具体的代码示例,帮…

    2025年12月16日
    000
  • 如何在Golang中使用channel实现生产者消费者_Golang channel生产者消费者实践汇总

    答案是使用单向channel和goroutine实现生产者消费者模型。通过producer函数向channel发送数据,consumer函数接收并处理数据,最后用done channel通知完成,确保并发安全与正确关闭。 在Golang中,channel 是实现并发通信的核心机制,非常适合用于构建生…

    2025年12月16日
    000
  • 在Go语言中实现Numpy的arange功能

    本文探讨了如何在go语言中高效且精确地实现类似numpy `arange` 函数的功能,即生成一个指定区间内均匀间隔的浮点数切片。重点介绍了如何通过避免浮点数累积误差来确保结果的准确性,并提供了一个健壮的go函数实现及其详细解析。 引言:理解Numpy arange 及其在Go中的需求 Numpy库…

    2025年12月16日
    000
  • Go语言数据库操作:深入理解预处理语句与直接查询

    Go语言的`database/sql`包提供了一个高度抽象的数据库接口,其设计旨在兼容各种SQL数据库系统。无论是使用预处理语句还是直接查询并传递参数,`database/sql`包都通过底层的数据库驱动程序确保了参数的安全性处理,有效防止SQL注入。预处理语句尤其适用于高频重复执行的查询,能通过数…

    2025年12月16日
    000
  • Go语言对象工厂模式:利用接口实现多态创建不同类型对象

    本教程探讨了在go语言中如何实现一个灵活的对象工厂模式,以根据输入动态创建不同类型的对象。通过深入理解go的接口机制,我们展示了如何定义一个通用接口,并让不同的结构体类型隐式实现该接口,从而使工厂函数能够返回一个接口类型,实现多态行为,克服了go语言中没有传统继承的限制。 引言:动态对象创建的挑战 …

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信