透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

本文主要是介绍透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引言

随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。

「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验知识,而模型问答其实就是引导大模型给出相关先验知识的过程」。对于提高大模型的性能,一种常见的方法就是不断的增加模型计算、Token和参数来提升规模。虽然这种方法可以让模型具备更广泛的知识,但是如何让这些基础模型在特定的下游能力上变得有用和高效(本质就是让模型给出符合预期的先验知识)。「这是目前大模型研究的一个主要方向:模型数字驯化研究,也就是我们平时说的模型调优」。本文总结介绍了目前学术界最主要的**「5种模型调优方法」,并结合对5种方法的分析,给出了一个「优化算法选择的思路框架」**。

背景介绍

训练大型语言模型(LLMs)和视觉语言模型(VLMs)的过程关键依赖于大量的互联网数据。像Transformer这样的高容量模型架构已经展示了对极其多样的数据分布进行有效建模的重要能力。这些大型模型在训练过程中接触各种各样的数据,包括优雅的小说散文和恶意的帖子、杰出的软件项目和有缺陷的代码、精美的专业摄影和业余自拍照片。虽然这些模型可以反映数字人类体验,但它们无法产生高质量、可取且一致的输出,然而这在大规模用户应用中是必需的。

我们应该认识到这些原始模型并不是糟糕的模型,它们实际上是对训练数据的分布进行建模。尽管这些底层数据分布可能包含不可取的特性,但也包含了良好特性、多样性和规模,这些是实现高性能模型的必要条件。「一个流行的假设是,模型的知识和能力主要在预训练阶段学习,而对齐过程则是引导模型在推理过程中使用哪些先验分布」。因此,如何在数据集中放大好的先验知识并抑制不好的先验知识,以及如何驯服从互联网分布中直接捕获的原始模型,成为一个重要问题。

过去一年里,有几种主要的方法逐渐流行起来。尽管它们的技术基础和优势各不相同,但它们都具有一个共同的目标:如何对一组期望先验进行放大,将其映射到模型对互联网规模数据集的理解上。本文主要研究各种先验放大方法和显著的用法示例,并提供一个算法选择的思路框架

Prompting

通过精心设计的提示(prompt)来引导一个基础模型朝着期望的先验方向进行是目前门槛最低的方法,有时候该方法也被成为无梯度调优。prompt利用了训练时看到的关联和先验信息,例如高ELO分数的国际象棋比赛会有更强的走法,因此在测试时,一个好的prompt应该明确告诉模型它处于高水平的国际象棋比赛中,并做出像大师一样精确的预测。

prompt工程存在一些局限性,它是一种机会主义策略,即提示策略高度依赖于原始训练数据集中出现的模式、相关性和先验信息。成功的prompt工程需要在提示过于通用和过于具体之间取得平衡,因为如果提示过于通用,模型可以成功地跟随,但可能没有太大用处;而如果提示过于具体,则虽然有用,但模型无法泛化到其他情况。此外,prompt工程还受到训练数据分布中不理想数据的相关性的影响,这被称为“Waluigi效应”,从而导致提示无法有效地放大先验。

基于以上分析,为了更有效地放大先验信息,对原始模型进行微调是否可以避免零样本提示的局限性呢?

监督微调(SFT)

监督微调(Supervised Finetuning,SFT)主要思路是:首先使用在多样化数据集上预训练的原始模型,然后在规模较小但质量更高的数据集上进行进一步训练,这些数据集可以是原始数据集的子集,也可以不是。其中微调数据集充当包含所有最终模型所需属性的黄金标准。这种简单性提出了一个有说服力的论点:「将目标数据集提供给原始模型,SFT承诺将原始模型靠近目标分布」。由于SFT是监督学习,如果数据好且模型庞大,成功是有保证的。

SFT的范围对于微调数据集的来源也很灵活。它可以是原始多样化数据集的子集,也可以是全新的自定义数据集。它可以通过人工创建和验证,也可以使用设计的启发式和规则进行自动获取,它也可以通过合成生成。图片 但是假设我们选择了一个特定的微调数据集,代表了我们希望融入模型的所有良好先验条件:「那么如何对基础模型进行微调呢」?在这里,也有几种选择:

  • 标准的SFT对整个基础模型进行微调,更新整个网络的权重。这是可能引起底层模型行为显著变化的最详尽的更新类型。
  • 轻微的方式进行微调,只有网络的某个子集可以进行微调;LiT就是一个例子,它在微调语言编码器的同时冻结了CLIP图像编码器。
  • 参数高效微调(Parameter-Efficient Finetuning,PEFT)是最近刚刚出现的新方法,该方法冻结了原始模型的大部,仅微调相对较小的模型参数集。像LoRA这样的PEFT方法就是非常大的创新,它使得消费者硬件就能够对相当大的基础模型进行微调。显然,「SFT的实现方式正在迅速发展,并且在可预见的未来可能仍将是一个令人兴奋的领域」。无论具体的SFT方法如何,对底层微调数据集的组成和质量都有很大的依赖。在SFT中,扩大哪些先验条件和如何扩大它们同样重要。

RLHF

RL微调引入了一个奖励模型,这是一个独立的组件,旨在在训练过程中直接为模型输出提供细粒度的反馈信号。其中最流行的RL微调范式之一是基于人类反馈的RL(RLHF),其中奖励模型直接根据人类偏好标签进行训练。与SFT采用的非参数方法不同,RLHF则相反,即通过参数化的奖励模型明确学习良好的先验知识,然后在训练过程中直接“告诉”原始模型这些偏好。将自回归标记预测视为强化学习问题有两个优势:「直接的在线反馈」「在次优数据上进行训练」

「首先,基于在线策略的学习信号非常有用,与标准离线离策略训练期间看到的信号在性质上有很大的不同」。在线反馈使模型了解“你的最佳预测有多好?”而离策略反馈告诉模型“这个其他预测会有多好?”。然而,除了在线反馈最具信息量之外,有时离策略反馈可能过时且不正确:预先收集的训练数据集包含在真空中存在的目标标签,并未考虑模型的当前能力。

「其次,RLHF提供了细粒度的奖励,使得可以在次优数据上进行训练」。而SFT设置只允许在包含或排除不同质量数据之间设定硬性界限,RLHF则采用更灵活的方法,在奖励模型训练期间和使用奖励模型进行微调期间都能够利用次优数据。在奖励模型训练期间,可以包含各种质量的数据,以使奖励模型更具鲁棒性。在基础模型微调期间,奖励模型能够输出多个细粒度的奖励尺度(例如,“正确+自信”的1.0奖励,"正确+不自信"的0.5奖励以及“错误+自信”的-2.0奖励),从而有效利用不同类型的次优数据。

除了这两个技术优势之外,还有一个系统级的优势,即将奖励模型视为一个独立组件,可以进行迭代研究和改进。这提供了非常微妙的奖励建模的潜力,然后可以将非常细粒度的反馈传递给原始基础模型。这在实证上得到了支持,因为与成功的RLHF微调相比,SFT似乎会导致基础模型的指令跟随行为发生较大变化。

RLAIF

RLHF通过将人类知识转移给AI模型提供了强大的机制,但也面临一些实际限制:人类反馈可能会存在噪音、不一致性,并且收集起来成本高昂。为了应对这些挑战,RLAIF旨在将现有的AI模型引入到反馈循环中,通过利用预训练模型生成用于训练奖励模型的偏好数据。RLAIF利用提示的基础模型中包含的良好先验生成自动化的偏好数据,无需人类参与,用于下游奖励模型的训练。

此外,基础模型可以充当AI评论家,不仅可以生成数据用于奖励模型,还可以直接成为奖励模型。在推理阶段,基础模型尝试完成任务并进行自我反思。在训练阶段,基础模型提供直接的策略反馈,将良好的先验知识融入到微调模型中。

合成数据生成SDG

AI 模型是否也可以改进我们获取和标记全新数据集的方式?更进一步,人工智能模型能否生成足够高质量的有用数据以供后续训练呢?

「一种可能的方法是不完全取代人类在数据引擎环节中的作用,而是通过共享自治的范式来增强人类能力」。AI模型的预测可能不是完美的,但可能是一个足够好的起点,可以节省人类标注的时间。例如,特斯拉自动驾驶团队的视觉数据引擎使用自动标签来进行诸如3D物体分割和车道检测等任务,并作为人类标注员进行校正的初始起点。最近,Meta发布了SA-1B分割掩码数据集,通过一种交互式的模型辅助标注过程,比完全手动标注的方法快6.5倍。

「除了协助人类标注员之外,生成建模的进步是否能够在完全没有人类参与的情况下创建有用的合成数据」?过去已经广泛研究了这个想法,称为半监督学习或伪标签;这篇博文是对2021年之前半监督学习的一个很好的概述。但是,2021年以后,在语言和视觉领域中性能出色的大规模模型的普及极大地增加了合成数据生成的潜力。过去,合成标签依赖于狭窄的特定领域模型,现在合成标签可以由不特定于当前任务的通用模型产生。这有两个好处:降低了尝试合成数据生成的成本,并有可能将互联网规模的常识引入到特定的训练领域中。

使用大规模通用模型进行狭窄合成生成”的这一概念已经在各种领域中得到越来越广泛的探索。

最佳策略

那么,对于大模型的最佳微调策略是什么?

图片

目前,已经有一些可行的建议可以得出结论。总结比较早期的方法,在做出有关先验放大的设计时,需要考虑一些潜在问题:

  • 原始训练语料库是否包含您想要的所有能力和先验?如果是,请尝试提示;如果否,微调模型。
  • 获取不同的微调数据集是否容易?如果是,请尝试 SFT;如果否,请尝试 RLHF 或 AI 反馈。
  • 您可以访问大量计算吗?如果是,微调整个模型;如果否,请使用 PEFT。
  • 现有的 AI 模型是否足以生成数据或验证数据?如果数据生成足够好,请尝试创建合成数据(SDG);如果足以验证但不能生成,请尝试使用 AI 反馈 (RLAIF) 或自我反思;如果两者都不是,请坚持使用 RLHF。

从更广泛的角度来看,我们需要认识到**「AI助力先验分布放大过程是一把双刃剑」**。随着AI模型在数据整理和训练过程中的越来越广泛应用,这些AI模型中预设的先验知识也会被传递下来——包括可取和不可取的先验知识。讨论过的所有微调方法都可以反复应用多次,每次生成的“学生”模型都会成为下一代的“老师”。因此,随着时间的推移,与过去简单的模型训练血统相比,特定先验知识的原始来源开始变得模糊不清。这对AI领域的技术方法论、安全性和控制偏见具有非常现实的影响。本文源自:https://thegradient.pub/ai-is-domestification/

如何学习AI大模型?

作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

一、全套AGI大模型学习路线

AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!

img

二、640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。

img

三、AI大模型经典PDF籍

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。

img

四、AI大模型商业化落地方案

img

作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量。

这篇关于透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的