用于文本分类的通用语言模型微调外文翻译资料

 2021-12-11 19:55:08

英语原文共 12 页

2019年 2 月 27 日

用于文本分类的通用语言模型微调

摘要: 归纳迁移学习对于计算机视觉有很大的影响,但现有的NLP中的方法仍然需要特定任务的修改和从头开始的训练。我们提出通用语言模型微调(ULMFiT),一种可以应用NLP中任何任务的迁移学习方法。同时,我们将介绍微调语言模型的关键技术。 我们的方法在6个文本分类的任务上显着优于当前最好模型,并再大多数数据集上减少18-24%的错误率。而且,即使只有100个标签示例,它的表现可以和100倍数据从头开始训练的效果相比拟。 我们开放了我们的预训练模型和代码 。

  1. 引言

归纳迁移学习对计算机视觉(CV)产生了很大的影响关于。 应用CV模型(包括对象检测,分类和语义分割)很少从头开始训练,而是用已有的模型进行微调,如在ImageNet,MS-COCO等数据集上预训练的模型。

文本分类是具有现实应用的一个自然语言处理任务类别,如:垃圾邮件,欺诈和机器人检测等应用程序,应急响应和商业文件分类,如用于法律发现。

虽然深度学习模型许多NLP任务上达到了最好的效果,但这些模型无一不是从头开始训练的,需要大型数据集和漫长的数据收集时间。目前自然语言处理中用到迁移学习的,主要是微调预训练的词嵌入,这是一种简单的迁移技术,它只针对模型的第一层,但在对实际效应有着巨大的影响,并运用于各种最好的模型中。最新的方法将来自其他任务的嵌入与不同层次的输入相结合,但仍然从头开始训练主要任务模型,并将预训练嵌入视为固定参数,限制了其有用性。

鉴于预训练的好处,我们应该能比随机初始化其余模型参数做得更好。但是,使用微调的迁移学习在NLP领域却暂时还未获得成功。 戴和乐 ( 2015年 )首先提出,我们可以微调语言模型(LM),但需要数百万同领域文本以实现良好的效果,这严重限制了它的适用性。

我们表明,有问题的不是LM微调的想法, 而是我们缺乏有效地如何训练他们的知识,这阻碍了其更广泛的使用。 LM会过拟合于小型数据集并在微调一个分类器的时候遭受灾难性的遗忘。相对于CV而言,NLP模型通常更加浅,因此需要不同的微调方法。

我们提出了一种新方法–通用语言模型微调(ULMFiT),以解决这些问题,并各种NLP任务上实现鲁棒的归纳迁移学习,类似于微调ImageNet那样:相同的3层具有相同的超参数LSTM架构 ,没有添加除了微调dropout超参数之外的其他东西,并在6个文本分类任务中优于其他工业化的迁移学习方法。在IMDb上,使用100个标注的样板,ULMFiT可以达到用10倍数据从头开始训练的性能,再加上50k未标记的样例 - 则可以达到100倍以上数据的效果。

我们的贡献如下:1)我们提出通用语言模型微调(ULMFiT),一种可以在任何自然语言处理任务上实现类似CV的转移学习的方法。 2)我们提出动态微调,倾斜三角学习率,渐进式解冻,等新的技术来保持过往知识和避免微调中的灾难性遗忘。 3)我们六个代表性文本分类的达到了最好的效果,并在大多数数据集上减少了18-24%的误差。 4)我们的方法能够实现极其样本有效的迁移学习并进行广泛的消融分析。 5)我们制作了预训练模型,我们的代码将可以被更广泛的采用。

  1. 相关工作

CV中的迁移学习 CV中深度神经网络从第一层到最后一层的特征被从一般性任务迁移到特殊的任务。 出于这个原因,CV中的大多数工作都集中在转移模型的第一层.Sharif Razavian et al(2014)使用ImageNet模型的特征作为简单分类器的输入来实现最终结果。 近年来,通过微调预训练模型的最后一层或几层,并使剩余的层冻结的新方法,已经取代了这种方法。

Hypercolumns 在NLP中,最近才有非词嵌入的迁移学习方法被提出。 流行的做法是预训练嵌入,通过其他任务获取额外的上下文信息。 然后将不同级别的嵌入用作特征,与单词嵌入或中间层的输入连接。 这种方法就是是CV中已知的hypercolumns,并最近在NLP被彼得斯等人分别使用语言建模,释义,蕴涵和机器翻译(MT)进行预训练。但是,彼得斯等人的方法需要设计定制的架构,而我们在一系列任务中使用相同的基本架构展示出了最先进的性能。 同时,在CV中,hypercolumns也几乎已经完全被端到端的微调所取代。

多任务学习 还有一个相关的方向是多任务学习(MTL)。 这是Rei(2017)和Liu(2018)等人采用的方法。 他们将语言建模目标添加到与主任务模型联合训练的模型中。 MTL要求每次都从头开始训练任务,这使得效率低下并且通常需要仔细权衡任务特定的目标函数。

微调 微调已经被成功的用于相似任务的迁移,例如, 在QA中,对于远程监督的情绪分析,或在MT领域,但已被证明在不相关的情绪之间效果不好。 Dai和Le(2015)也对语言模型进行了微调,但过度使用了10k标记的示例,需要数百万个域内文档才能获得良好的性能。 相比之下,ULMFiT利用通用域预训练和新颖的微调技术来防止过度拟合,即使只有100个标记示例,也可以在小数据集上实现最先进的结果。

3 通用语言模型微调

我们对NLP最普遍的归纳迁移学习设置感兴趣:给定静态源任务TS和TS ! = TT的任何目标任务TT,我们希望提高TT的性能。语言建模可以被视为理想的源任务和ImageNet for NLP的对应物:它捕获了与下游任务相关的语言的许多方面,例如长期依赖,层次关系和情绪。与MT和蕴涵

图1:ULMFiT由三个阶段组成:a)LM在一般领域语料库上进行训练,以捕获不同层次语言的一般特征。 b)使用判别性微调(lsquo;Discrrsquo;)和倾斜三角学习率(STLR)对目标任务数据进行微调,以学习任务特定的功能。 c)使用逐渐解冻,#39;Discrrsquo;和STLR对目标任务进行微调,以保留低级表示并适应高级表示(阴影:解冻阶段;黑色:冻结)。

等任务相比,它为大多数域和语言提供接近无限数量的数据。此外,预训练的LM可以很容易地适应目标任务的特性,我们可以显着提高性能。此外,语言建模已经是MT和对话建模等现有任务的关键组成部分。形式上,语言建模引发了一个假设空间H,它应该对许多其他NLP任务有用。

我们提出通用语言模型微调(ULMFiT),它在大型通用域语料库中预先训练语言模型(LM),并使用新技术在目标任务上对其进行微调。 该方法在满足以下实际标准的意义上是通用的:1)它适用于不同文档大小,数量和标签类型的任务; 2)它使用单一的架构和训练过程; 3)它不需要自定义特征工程或预处理; 4)它不需要额外的域内文件或标签。

在我们的实验中,我们使用最先进的语言模型AWD-LSTM(Merity等,2017a),一个常规LSTM(没有注意,快捷连接或其他复杂的添加),具有各种调谐dropout超参数。 与CV类似,我们预计未来可以通过使用更高性能的语言模型来提高下游性能。

ULMFiT包括以下步骤,我们在图1中显示:a)通用域LM预训练(x3.1); b)目标任务LM微调(x3.2); c)目标任务分类器微调 (X3.3)。 我们将在以下部分讨论这些内容。

3.1 通用域LM预训练

类似ImageNet的语言语料库应该很大并且可以捕获语言的一般属性。 我们预测了Wikitext-103上的语言模型,该模型包含28,595个预处理的维基百科文章和1.03亿个单词。 预训练对于具有小数据集的任务最有利,并且即使使用100个标记示例也能够进行泛化。 我们将更多样化的预训练语料库的探索留给未来的工作,但期望它们会提升性能。 虽然这个阶段是最昂贵的,但它只需要执行

一次并改善下游模型的性能和收敛性。

3.2 目标任务LM微调

判别微调 由于不同的层捕获不同类型的信息,它们应该在不同程度上进行微调。 为此,我们提出了一种新颖的微调方法,即辨别性的微调。

不是对模型的所有层使用相同的学习速率,而是区分性微调允许我们以不同的学习速率调整每个层。 对于上下文,时间步长t处模型参数theta;的常规随机梯度下降(SGD)更新如下所示:

theta;t​ = theta;tminus;1 ​minus; eta;sdot;nabla;theta;J(theta;) (1)

其中eta;是学习率,nabla;theta;J(theta;)是关于模型目标函数的梯度。对于判别性微调,我们将参数theta;分成{theta;1,...,theta;L}其中theta;L包含第L层模型的参数,L是模型的层数。同样,我们得到

{eta;1,...,eta; L}其中eta;L是第L层的学习速率。

具有判别性微调的SGD更新如下:

= — sdot; nabla;theta;l J(theta;) (2)

图2:倾斜的三角学习率用作ULMFiT的时间表作为其功能训练迭代次数。

我们凭经验发现,首先选择最后一层的学习率eta;L,仅微调最后一层, 然后通过使用eta;lminus;1=eta;l/2.6 作为较低层的学习率,是最有效的。

倾斜的三角学习率 为了使其参数适应任务特定的特征,我们希望模型在训练开始时快速收敛到参数空间的合适区域,然后细化其参数。 在整个训练过程中使用相同的学习率(LR)或退火学习率并不是实现此行为的最佳方法。 相反,我们提出倾斜的三角学习率(STLR),它首先线性地增加学习率,然后根据以下更新时间表线性衰减它,如图2所示:

其中T是训练迭代的次数,cut_frac是我们增加LR的迭代的分数,cut是当我们从增加切换到减少LR时的迭代,p是我们增加或将减少的迭代次数的分数, ration指定最小LR与最大LR eta;max相比小多少,eta;t是迭代t时的学习速率。 我们通常使用cut_frac = 0.1,ratio = 32和eta;max= 0:01。 ST LR修改了三角学习率(Smith,2017),具有短期增长和长衰减期,这是我们发现良好性能的关键。在第5节中,我们将比较积极的余弦退火,一种最近用于在CV中实现最先进性能的类似计划。

无论用于预训练的通用域数据多么多样,目标任务的数据可能来自不同的分布。 因此,我们微调LM目标任务的数据。 给定一个预训练的通用域LM,这个阶段收敛得更快,因为它只需要适应目标数据的特性,它允许我们训练一个强大的LM,即使对于小数据集。 我们提出了用于微调LM的判别微调和倾斜三角学习速率,我们在下面介绍。

3.3 目标任务分类器微调

最后,为了微调分类器,我们使用两个额外的线性块来增强预训练语言模型。 遵循CV分类器的标准实践,每个块使用批量标准化和dropout,中间层的ReLU激活和softmax激活,在最后一层输出目标类的概率分布。 请注意,这些特定于任务的分类器层中的参数是从头开始学习的唯一参数。 第一个线性层将合并的最后隐藏层状态作为输入。

pooling拼接 文本分类任务中的信号通常包含在几个单词中,这些单词可能出现在文档中的任何位置。 由于输入文档可能包含数百个单词,如果我们只考虑模型的最后隐藏状态,信息可能会丢失。 出于这个原因,我们将文档的最后一个步骤hT的隐藏状态与各时间步长的隐藏状态的max-pooled和mean-pooled表示拼接,获得一个gpu显存相对合适的文本表示:H = {h1,hellip;,hT}:

hc = [hT , maxpool(H), meanpool(H)] (4)

其中[]是级联

微调目标分类器是转移学习方法中最关键的部分。 过于激进的微调将导致灾难性的遗忘,消除通过语言建模捕获的信息的好处; 过于谨慎的微调会导致收敛缓慢(以及由此导致的过度拟合)。 除了差别性微调和三角学习率之外,我们还建议逐步解冻以微调分类器.

逐渐解冻 我们建议从最后一层开始逐渐解冻模型,而不是一次微调所有层,这会导致灾难性的遗忘,因为这包含最少的一般知识:我们首先解冻最后一层, 在一个时期内微调所有未冻结的层。 然后我们解冻下一个较低的冻结层并重复,直到我们微调所有层,直到最后一次迭代收敛。 这类似于rsquo;链解冻rsquo;,不过我们一次向一组rsquo;解冻rsquo;层添加一层,而不是一次只训练一层。

区别性微调,倾斜三角学习率和逐渐解冻都是有益的,我们在第5节中表明它们相互补充并使我们的方法能够在不同的数据集中表现良好。

用于文本分类的BPTT(BPT3C)通过时间反向传播(BPTT)训练语言模型,以实现大输入序列的梯度传播。

资料编号:[5836]

原文和译文剩余内容已隐藏,您需要先支付 30元 才能查看原文和译文全部内容!立即支付

以上是毕业论文外文翻译,课题毕业论文、任务书、文献综述、开题报告、程序设计、图纸设计等资料可联系客服协助查找。