LLM2LLM: Boosting LLMs with Novel Iterative Data Enhancement

LLM2LLM: Boosting LLMs with Novel Iterative Data Enhancement

相关链接:arXiv GitHub
关键字:LLMData AugmentationFine-tuningNLPLow-data Regime

摘要

预训练的大型语言模型(LLMs)目前是解决绝大多数自然语言处理任务的最新技术。尽管许多实际应用仍然需要微调以达到令人满意的性能水平,但许多应用处于低数据量状态,这使得微调变得具有挑战性。为了解决这个问题,我们提出了LLM2LLM,这是一种针对性和迭代式的数据增强策略,它使用教师LLM通过增加可用于特定任务微调的数据来增强小型种子数据集。LLM2LLM (1) 在初始种子数据上微调基线学生LLM,(2) 评估并提取模型出错的数据点,并 (3) 使用教师LLM基于这些错误数据点生成合成数据,然后将这些数据点重新添加到训练数据中。这种方法在训练期间通过LLM放大了错误预测数据点的信号,并将它们重新整合到数据集中,以便专注于LLM更具挑战性的例子。我们的结果表明,LLM2LLM显著提高了LLM在低数据量状态下的性能,超越了传统的微调和其他数据增强基线。LLM2LLM减少了对劳动密集型数据策划的依赖,为更可扩展和高性能的LLM解决方案铺平了道路,使我们能够处理数据受限的领域和任务。我们在低数据量状态下使用LLaMA2-7B学生模型,在GSM8K数据集上实现了高达24.2%的改进,在CaseHOLD上为32.6%,在SNIPS上为32.0%,在TREC上为52.6%,在SST-2上为39.8%,相比于常规微调。

核心方法

在这里插入图片描述

LLM2LLM的核心方法包括以下几个步骤:

  1. 微调学生模型:在初始种子数据上微调基线学生LLM。
  2. 评估和提取错误数据:评估学生模型在训练数据上的表现,并提取模型回答错误的数据点。
  3. 生成合成数据:使用教师LLM基于错误数据点生成新的合成数据,这些数据点在语义上与原始数据点相似但在表述上有所不同。
  4. 迭代数据增强:将生成的合成数据添加回训练集中,并在新的数据集上重复微调过程,以进一步提高模型性能。

实验说明

实验结果展示了LLM2LLM在不同数据集上的测试准确率提升情况。数据集包括GSM8K、CaseHOLD、SNIPS、TREC和SST-2,涵盖了从0.02%到50%的不同种子数据比例。实验中,我们使用了LLaMA2-7B作为学生模型,并以GPT-3.5作为教师模型。实验结果表明,LLM2LLM在低数据量状态下显著提高了模型性能,尤其是在数据量较少的情况下。

数据集 基线微调准确率 LLM2LLM准确率
GSM8K 0.00% 19.56% - 38.67%
CaseHOLD 12.28% 66.50% - 88.14%
SNIPS 11.86% 92.14%
TREC 11.20% 78.80% - 90.20%
SST-21 27.06% 92.66% - 94.04%

结论

我们介绍了LLM2LLM,这是一种自适应和迭代的基于LLM的数据增强框架,使用LLM来扩展较小的微调数据集,而不是手动生成更多数据。这种方法由于其迭代和针对性的本质而有效,它允许我们从LLM出错的数据点中增强信号。因此,我们能够在使用LLaMA-2-7B学生模型的低数据量状态下,在GSM8K、CaseHOLD、SNIPS、TREC和SST-2数据集上实现了显著的性能提升。未来的工作可以集中在调整我们框架的超参数上,以及将我们的方法与其他LLM技术(如提示调整和少样本学习)结合起来。

相关推荐

  1. 2、ipex-llm(原bigdl-llm)应用聊天

    2024-03-25 16:52:04       14 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-25 16:52:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-25 16:52:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-25 16:52:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-25 16:52:04       20 阅读

热门阅读

  1. 我的算法刷题笔记(3.18-3.22)

    2024-03-25 16:52:04       21 阅读
  2. 什么是微任务?什么是宏任务?

    2024-03-25 16:52:04       19 阅读
  3. IOS面试题编程机制 31-35

    2024-03-25 16:52:04       17 阅读
  4. JVM G1垃圾回收器的工作内容

    2024-03-25 16:52:04       17 阅读
  5. 5.86 BCC工具之tcpstates.py解读

    2024-03-25 16:52:04       17 阅读
  6. 1928递归去处理压缩字符串

    2024-03-25 16:52:04       18 阅读
  7. P5963 [BalticOI ?] Card 卡牌游戏 贪心

    2024-03-25 16:52:04       20 阅读
  8. [Repo Git] manifests的写法

    2024-03-25 16:52:04       23 阅读
  9. 常用ES标准

    2024-03-25 16:52:04       19 阅读
  10. [leetcode] 26. 删除有序数组中的重复项

    2024-03-25 16:52:04       18 阅读
  11. String、StringBuilder、StringBuffer

    2024-03-25 16:52:04       15 阅读
  12. 【C语言】指针基础

    2024-03-25 16:52:04       19 阅读