设为书签 Ctrl+D将本页面保存为书签,全面了解最新资讯,方便快捷。 您也可下载桌面快捷方式。点击下载 | 新浪科技 | 新浪首页 | 新浪导航

开源Llama版o1来了,3B小模型反超80B,逆向工程复现OpenAI新Scaling Law

2024-12-17 12:04:40    创事记 微博 作者:   

梦晨 发自 凹非寺

量子位 | 公众号 QbitAI

o1完整版公开仅10天,Scaling Law新范式就被逆向工程复现了!

Hugging Face官方发文,开源了扩展测试时计算的方法。

用在小小小模型Llama 1B上,数学分数直接超过8倍大的模型也超过了计算机科学博士生的平均分数(40%)

那么用在Llama 3B上呢?进步幅度更大,甚至能和20几倍大的70B模型媲美。

虽然OpenAI o1的配方完全保密,没有发布实现细节或代码,但团队基于DeepMind公布的研究结果,完成了自己的实验。

在DeepMind研究的基础上,Hugging Face团队做出如下改进:

  • 多样化验证器树搜索(Diverse Verifier Tree Search),一种简单而有效的方法,可以提高多样性和更高性能,特别是在算力预算充足的情况下。

  • 开源轻量级工具包Search and Learn,与推理框架vLLM配合,快速构建搜索策略

测试时计算扩展策略

目前扩展测试时计算主要有两种策略:自我优化和搜索。

自我优化中,模型识别和纠正后续迭代中的错误来迭代优化自己的输出或“想法”。

团队认为虽然此策略对某些任务有效,但通常要求模型具有内置的自我优化机制,这可能会限制其适用性。

搜索方法侧重于生成多个候选答案并使用验证器选择最佳答案。

搜索策略更灵活,可以适应问题的难度。Hugging Face的研究主要聚焦于搜索方法,因为实用且可扩展。

其中验证器可以是任何东西,从硬编码到可学习的奖励模型,这里将重点介绍可学习的验证器。

具体来说,研究涉及三种搜索策略:

  • Best-of-N

为每个问题生成多个响应,并使用奖励模型为每个候选答案分配分数。选择分数最高的答案(或加权变体),这种方法强调答案质量而不是频率。

  • Beam search

一种探索解决方案空间的系统搜索方法,通常与过程奖励模型 (PRM) 相结合,以优化解决问题中中间步骤的采样和评估。与在最终答案上产生单个分数的传统奖励模型不同,PRM提供一系列分数,推理过程的每个步骤分配一个分数。这种提供精细反馈的能力使PRM非常适合大模型。

  • 多样化的验证器树搜索(DVTS)

新开发的Beam search变体,它将初始Beam拆分为独立的子树,然后使用PRM做贪婪扩展。这种方法可以提高解决方案的多样性和整体性能,尤其是在测试时算力预算较大的情况下。

实验设置:3种搜索策略PK

  • 首先将数学问题提供给大模型,生成N个中间步骤。

  • 每个步骤都由PRM评分,估计每个步骤最终能得出正确答案的概率。

  • 给定的搜索策略使用这些步骤和PRM分数,来选择应该进一步探索哪些方向,生成下一轮中间步骤。

  • 搜索策略终止后,PRM将对最终候选解决方案进行排名,以生成最终答案。

为了比较各种搜索策略,研究中使用了以下开放模型和数据集:

语言模型,Llama-3.2-1B-Instruct作为主要实验对象,因为轻量级模型可以快速迭代,并且在数学基准测试中性能不饱和

流程奖励模型,使用了Llama3.1-8B-PRM-Deepseek-Data,与语言模型同属一个系列,且在测试中给出了更好的结果。

数据集,使用MATH基准测试的子集MATH-500,该子集由OpenAI发布,数学问题横跨7个科目,对人类和大多数模型来说都有挑战性。

实验结果:动态分配策略达到最优

首先,多数投票策略比贪婪解码基线有显著改进,收益在大约N=64后趋于稳定。

团队认为,之所以出现这种限制,是因为多数投票难以解决需要细致入微推理的问题,或者解决几个答案错到一块去的任务。

奖励模型加入后的策略,表现均有提高。

Best-of-N策略分为两种变体,原版(Vanilla)不考虑答案之间的一致性,加权版(Weighted)汇总所有结果相同的答案,并选择总分数最高的。

结果发现加权版始终优于原版,特别是在算力预算大的时候更明显,因为确保了频率较低但质量较高的答案也能获选。

Beam Search策略终于让1B模型表现开始高于8B。

但Beam Search并不是万金油方法,在简单的问题上表现反而不如Best-of-N。

团队通过查看结果树,发现如果一个中间步骤获得了高分,那么整个树就会坍塌到这一步,影响了后续答案的多样性。

最终,DVTS方法改进了答案的多样性,该方法与BeamSearch相比有以下不同之处:

  • 对于给定的Beam宽度(M)和生成数量N,初始Beam集设定为N/M个独立子树

  • 对于每个子树,选择PRM分数最高的步骤

  • 生成M个新的下一步,继续选择分数最高的

  • 重复这个过程,直到生成EOS token后终止,或达到最大深度

在对问题难度细分后,发现DVTS方法在N比较大时增强了对简单/中等难度问题的性能。

而Beam Search在N比较小时仍然表现最好。

最终基于问题难度动态分配策略的方法可以取得最佳成绩。

最后团队提出,未来这项技术还有更多值得探索的地方:

  • 更强大的验证器,提高其稳健性和泛化能力至关重要。

  • 最终目标是实现自我验证,目前在实践中仍然难以实现,需要更细致的策略。

  • 在生成过程中加入明确的中间步骤或 “想法” ,通过将结构化推理整合到搜索过程中,可以在复杂任务中获得更好的性能。

  • 搜索方法可以用于合成数据,创建高质量的训练数据集

  • 开放的流程奖励模型目前数量较少,是开源社区可以做出重大贡献的领域

  • 目前的方法在数学和代码等领域表现出色,这些问题本质上是可验证的,如何将这些技术扩展到结构性较差或评判标准主观的任务,仍是一个重大挑战。

评论区有网友表示,这种方法更适合本地部署,而不是API调用,因为调用256次3B模型和过程奖励模型,通常会比调用一次70B模型更贵。

也有人建议在Qwen系列模型上尝试,以及指路天工Skywork发布了两个基于Qwen的PRM模型

开源代码:

https://github.com/huggingface/search-and-learn

参考链接:

[1]https://huggingface.co/spaces/HuggingFaceH4/blogpost-scaling-test-time-compute

[2]https://x.com/_lewtun/status/1868703456602865880

(声明:本文仅代表作者观点,不代表新浪网立场。)

分享到:
保存   |   打印   |   关闭