Deduplicating Training Data Makes Language Models Better
Last updated
Last updated
近年来,自然语言处理(NLP)领域取得了显著进展,这在很大程度上归功于大规模文本语料库的发展,这些语料库用于训练越来越大的语言模型。然而,这些大规模数据集由于手动审查和整理的成本高昂,往往在质量上不如较小的先前版本。论文指出,现有语言模型数据集中存在许多近乎重复的例子和长重复子字符串,导致训练语言模型的输出中有超过1%是直接从训练数据中复制的。
过去的数据集已经进行了一些基本形式的去重工作,但这些方法通常局限于简单的字符串匹配,不足以处理更复杂的重复情况,如近似重复或模板化字段中的微小变化。此外,大规模数据集的彻底去重在计算上具有挑战性,并且需要复杂的技术。
本文提出了两种可扩展的技术来检测和删除重复的训练数据:
Exact Substring Matching:使用后缀数组来识别和删除数据集中的确切重复子字符串。
Approximate Full Document Matching:使用基于哈希的技术(MinHash)来识别具有高n-gram重叠的文档对。
提出了两种去重方法,能够更有效地识别和删除训练数据中的重复内容。
开发了工具和代码,允许研究者去除数据集中的重复项,提高了训练数据的质量。
证明了去重后的数据集可以减少模型对训练数据的过度记忆,提高模型的泛化能力。
通过实验表明,使用去重后的数据集训练的模型在准确性上没有损失,甚至在某些情况下可以提高。
实验使用了1.5B参数的Transformer-based语言模型,分别在原始数据集和去重后的数据集上进行训练。实验评估了模型在去重数据集上训练后的困惑度(Perplexity),以及生成文本时对训练数据的复制情况。
使用去重数据集训练的模型在生成文本时,对训练数据的复制率降低了10倍。
在某些情况下,去重可以减少模型的困惑度,提高其在验证集上的表现。
去重数据集没有对模型的困惑度造成负面影响,反而在某些情况下有所改善。
文章鼓励未来的语言模型研究进行数据集去重,无论是使用作者发布的去重数据集,还是使用发布的去重工具,或者遵循作者的方法使用新工具进行去重。去重不仅提高了数据质量,还有助于减少模型对训练数据的过度记忆,从而提高了模型的泛化能力和隐私保护。
本文针对当前大规模语言模型训练数据集中存在的重复问题,提出了两种有效的去重方法,并通过实验验证了去重对提高模型性能和减少训练数据记忆倾向的积极影响。作者通过开源工具和代码,为研究者提供了一种提高数据集质量和模型泛化能力的手段。此外,文章还讨论了去重在隐私保护方面的潜在好处,为未来的NLP研究提供了新的视角和工具。
注:
删除重复数据对于提高语言模型训练数据集的质量至关重要,原因包括:
减少记忆效应:语言模型可能会对训练数据中的重复内容产生记忆效应,导致在生成文本时过度依赖这些内容,降低生成文本的多样性和创造性。
提高模型泛化能力:通过删除重复数据,模型可以学习到更广泛的语言特征,而不是过度拟合于某些特定的、重复出现的例子。
避免评估偏差:训练数据和验证/测试数据之间的重复会导致评估指标(如困惑度)被高估,从而影响对模型性能的准确评估。
减少训练成本:去重后的数据集更小,可以减少存储需求和训练时间,从而降低训练成本。
提高数据集质量:去除重复项可以确保数据集中的每个例子都是独特的,这有助于提升数据集的整体质量。
防止过拟合:重复数据可能导致模型对特定的文本片段过度拟合,而忽略学习其他多样化的语言表达。
隐私保护:训练数据中的重复项可能包含敏感信息,模型记忆这些信息可能会带来隐私泄露的风险。
提升模型公平性:重复数据可能来源于特定的数据源或群体,去除这些数据有助于减少模型对特定群体或类型的偏见。
优化资源分配:通过减少不必要的重复训练,可以更有效地利用计算资源来处理更多的独特数据。
提升研究可重复性:确保不同研究使用的数据集在质量上是一致的,有助于提高研究结果的可重复性和可靠性。
删除重复数据是提高语言模型训练过程质量和结果可靠性的重要步骤。