标签:col 就是 大小写 ict ast 直接 ide 架构 有趣的
本文尽量贴合BERT的原论文,但考虑到要易于理解,所以并非逐句翻译,而是根据笔者的个人理解进行翻译,其中有一些论文没有解释清楚或者笔者未能深入理解的地方,都有放出原文,如有不当之处,请各位多多包含,并希望得到指导和纠正。
BERT的设计是通过在所有层中对左右上下文进行联合调节,来预先训练来自未标记文本的深层双向表示。
预训练的BERT模型可以通过fine-tuned 在广泛的任务中创造新的最佳记录,比如问答任务,语言推理任务等,而不需要对BERT本身架构做实质性的修改。
BERT是一个概念上简单,实践结果强大的模型。其在11项自然语言处理任务中创造了新的最佳记录。
ELMo是基于feature-based【注解2】的方法应用pre-trained language representations的。
OpenAI GPT是基于fine-tuning【注解3】 的方法应用pre-trained language representations的。
上面两个方法在与训练阶段,共享相同的目标函数,它们使用单项语言模型来学习通用语言表征。
作者认为对于句子来说,单向注意力是次优的,对于token级别的任务,比如问答任务来说,就会带来不好的作用。因为在类似问答任务中,基于两个方向的上下文的结合非常重要。
本论文,作者通过提出BERT模型,来改善基于fine-tuning的方法。
BERT:Bidirectional Encoder Representations from Transformers.
BERT受到完型填空任务的启发,通过使用一个“masked language model”(MLM)预训练目标来减轻上面提到的单向约束问题。
MLM随机masks掉input中的一些tokens,目标是从这些tokens的上下文中预测出它们在原始词汇表中的id。不想left-to-right 的预训练语言模型,MLM目标使得表征融合了left和right的上下文信息,这允许作者预训练一个深度双向的Transformer模型。除了MLM,作者还使用了一个“next sentence prediction”任务,连带的预训练text-pair表征。本篇论文的贡献如下:
展示了双向预训练语言表征的重要性。BERT使用MLM使得模型可以预训练深度双向表征;GPT在预训练上使用单向语言模型;ELMo使用分别训练好的left-to-right 和right-to-left表征,然后仅仅是简单的串联在一起。
BERT 打破了11项NLP任务的最佳记录。代码和预训练模型可以从这里获取 。
预训练通用语言表征已经有相当长的历史了。本节简略看一下使用最广泛的预训练通用语言表征的方法。
数十年来,学习广泛适用的单词表示形式一直是一个活跃的研究领域,包括非神经领域和神经领域的方法。预训练词嵌入是现代NLP系统的主要部分,提供了从零开始学习词嵌入的显著改进。为了预训练词嵌入向量,人们使用过left-to-right语言建模目标,以及从左右上下文中区分出正确和不正确的单词的建模目标。
这些方法已经推广到更粗的粒度,比如句子嵌入,或段落嵌入。为了训练句子表征,之前的工作已经用过这些目标:下个候选句子排名;给定上一个句子的表征,left-to-right生成下一个句子;从自动编码器去噪。
ELMo和它的前身从不同的维度概括了传统的词嵌入研究。它们从left-to-right和right-to-left语言模型中提取上下文敏感的特征。每个token(单词、符号等)的上下文表征是通过串联left-to-right和right-to-left的表征得到的。在将上下文词嵌入和已有的特定任务的架构结合后,ELMo在几个主要NLP基准测试(包括:问答,情感分析,命名实体识别)上取得了最佳记录。Melamud等人在2016年提出了使用LSTMs模型通过一个预测单词左右上下文的任务来学习上下文表征。与ELMo类似,他们的模型也是基于feature-based方法,并且没有深度双向(注解1)。Fedus等人在2018年展示了完型填空任务可以用来改善文本生成模型的鲁棒性。
与feature-based方法一样,该方向刚开始只是在未标记的文本上预训练词嵌入参数(无监督学习)。
最近,句子和文档等生成上下文token表征的编码器已经从未标记的文本中预训练出来,并且通过fine-tuned的方式用在下游任务中。这些方法的优势在于很少需要从零开始学习参数。至少有部分是因为这个优点,OpenAI GPT之前在许多来自GLUE基准测试的句子级别的任务上达到了最佳水平。Left-to-right 语言建模和自动编码器目标用于训练这种模型。
也有工作展示了从大数据集的监督任务的做迁移学习的有效性,就像自然语言推理(NLI),和机器翻译。计算机视觉研究也展示了迁移学习的重要性,一个有效的技巧就是微调(fine-tune)ImageNet的预训练模型。
本节介绍BERT的详细实现。使用BERT有2个步骤:pre-training 和 fine-tuning。在预训练期间,BERT模型在不同任务的未标记数据上进行训练。微调的时候,BERT模型用预训练好的参数进行初始化,并且是基于下游任务的有标签的数据来训练的。每个下游任务有自己的微调模型,尽管最初的时候都是用的预训练好的BERT模型参数。图1中,问答领域的例子作为本节一个运行示例。
图1:BERT的pre-training和fine-tuning运行过程。除了output层,这两个阶段的架构是一样的。预训练模型的参数会做为不同下游任务的模型的初始化参数。在fine-tuning时,所有参数参与微调。[CLS]时一个特别设置的符号,添加在每个输入样本的前面,表示这是一个输入样本的开始,[SEP]是特别设置的一个分隔标记。比如分隔questions/answers。
BERT的一个与众不同的特性是它的跨任务的统一架构,即在预训练架构和下游的架构之间的差异最小。
BERT的模型架构是一个多层双向Transformer编码器,(关于Transformer可以看这篇文章)。因为Transformer的使用变得普遍,而且BERT的与Transformer相关的实现和原Tranformer几乎一样,所以本论文中不再详述,推荐读者去看原Transformer论文,以及“The Annotated Transformer”(这是对原论文中阐述的Transformer的一个极好的讲解)。
这里,作者指明L表示层数,H表示每个隐藏单元的维数大小,A表示self-attention头数。BERT有2种大小的模型,分别是BERT(base,L=12, H=768, A=12, Total Parameters=110M)和BERT(large,L=24, H=1024, A=16, Total Parameters=340M)。
BERT(base)设定为和OpenAI GPT的模型大小相同,以便作比较。需要重点说明的是,BERT Transformer使用双向self-attention,而GPT
Transformer 使用带约束的self-attention,每个token只能注意到它左边的上下文。
使用BERT做各种下游任务,输入表征可以在一个token序列里清楚的表示一个句子或者一对句子(比如<Question,Answer>)。这里的“句子”不是必须是语言句子,而可以是任意范围的连续文本。“sequence”指BERT的输入序列,可以是一个句子,也可以是两个打包在一起的句子。
作者使用了WordPiece embeddings来做词嵌入,对应的词汇表有30000个token。每个序列的首个token总是一个特定的classification token([CLS])。这个token对应的最后的隐藏状态被用作分类任务的聚合序列表征。句子对打包成一个序列。有两种区分句子对中的句子的方法。第一种,通过分隔符[SEP];第二种,模型架构中添加了一个经过学习的嵌入(learned embedding)到每个token,以表示它是属于句子A或者句子B。如图1中,E表示输入的词嵌入,C表示最后隐藏层的[CLS]的向量,Ti表示第i个输入token在最后隐藏层的向量。
对一个给定的token,其输入表征由对应的token,segment和position embeddings的相加来构造。如图2。
直观上来说,作者有理由相信,一个深度双向模型确实会比单向或者浅度双向模型要强大。
可惜,标准的条件语言模型只能从按照left-to-right或者right-to-left的方式训练,直至双向条件可以允许每个词间接的“see itself”,并且可以在多层上下文中预测目标单词。
Unfortunately, standard conditional language models can only be trained left-to-right or right-to-left, since bidirectional conditioning would allow each word to indirectly “see itself”, and the model could trivially predict the target word in a multi-layered context.(原句)
为了训练一个深度双向表征,作者简单的随机mask一些百分比的输入tokens,然后预测那些被mask掉的tokens。这一步称为“masked LM”(MLM),尽管在文献中它通常被称为完型填空任务(Cloze task)。
mask掉的tokens对应的最后的隐藏层向量喂给一个输出softmax,像在标准的LM中一样。在实验中,作者为每个序列随机mask掉了15%的WordPiece tokens。和 denoising auto-encoders相比,BERT的做法是只预测被mask掉的词,而不是重建完整的输入。
尽管这允许作者获得双向预训练模型,其带来的负面影响是在预训练和微调模型之间创造了不匹配,因为[MASK]符号不会出现在微调阶段。所以要想办法让那些被mask掉的词的原本的表征也被模型学习到,所以这里作者采用了一些策略,具体参见:附录 A.1。
许多下游任务,比如问答,自然语言推理等,需要基于对两个句子之间的关系的理解,而这种关系不能直接通过语言建模来获取到。为了训练一个可以理解句子间关系的模型,作者为一个二分类的下一个句子预测任务进行了预训练,这些句子对可以从任何单语言的语料中获取到。特别是,当为每个预测样例选择一个句子对A和B,50%的时间B是A后面的下一个句子(标记为IsNext), 50%的时间B是语料库中的一个随机句子(标记为NotNext)。图1中,C用来预测下一个句子(NSP)。尽管简单,但是该方法QA和NLI任务都非常有帮助。5.1节对此有展示。
NSP任务和 Jernite et al. (2017) and Logeswaran and Lee (2018)中的表示学习的目标密切相关。任务,先前的工作中,只将句子嵌入转移到了下游任务中,而BERT转移了所有参数来初始化终端任务模型的参数。
Pre-training data 预训练过程很大程度上参考了已有的语言模型预训练文献。预训练语料方面,作者使用了BooksCorpus(800M words),English Wikipedia(2500M words) 。作者只提取Wikipedia的文本段落,忽略列表,表格和标题。为了提取长连续序列,关键是使用文档级语料库,而不是像十亿词基准(Chelba et al., 2013)这样的无序的句子级语料库。
微调很简单,因为Transformer中的self-attention机制允许BERT通过交换合适的输入和输出来为许多下游任务建模——无论是单个文本还是文本对。对于涉及到文本对的应用,常见的模式是分辨编码文本对中的文本,然后应用双向交叉的注意力。BERT使用self-attention机制统一了这两个步骤,BERT使用self-attention编码一个串联的文本对,其过程中就包含了2个句子之间的双向交叉注意力。
输入端,句子A和句子B可以是:(1)释义句子对(2)假设条件句子对(3)问答句子对 (4)文本分类或序列标注中的text-?对。
输出端,对于,token表征喂给一个针对token级别的任务的输出层,序列标注和问答是类似的,[CLS]表征喂给一个分类器输出层,比如情感分析。
微调的代价要比预训练小的多。论文中的很多结果都从一个完全相同的预训练模型开始,在TPU上只要花费1小时的时间就可以复现,GPU上也只要几个小时。更多细节可以查看附录 A.5
本节展示了BERT在11项NLP任务上的fine-tuning结果。
GLUE基准测试是一系列不同的自然语言理解任务。GLUE数据集的详细描述在附录B.1中。
GLUE上的fine-tune,作者使用第3节描述的句子和句子对,用最后的隐藏向量C作为表征,C对应首个输入token([CLS])。分类器层的权重系数矩阵W (形状:K×H),K是类别的个数。 作者使用C和W计算标准的分类损失,比如log(softmax(C·W )).
在所有的GLUE任务上,作者使用了batch-size=32,epochs=3。对于每个任务,都通过开发集的验证来选择了最佳的微调学习率(在5e- 5,4e - 5,3e -5和2e-5之间)。另外,对于BERT的large模型,作者发现微调有时候在小数据集上不稳定,所以随机重启了几次,并选择了开发集上表现最佳的模型。With random restarts, we use the same pre-trained checkpoint but perform different fine-tuning data shuffling and classifier layer initialization.9(?)
BERT base版本的模型架构和OpenAI GPUT除了attention masking以外,几乎相同。
BERT large 版本明显比base版本要表现的更好。关于模型大小的影响,在5.2节有更深入的探讨。
这是一个100k的问答对集合。给定一个问题和一篇短文,以及对应的答案,任务是预测出短文中的答案文本span(the answer text span in the passage)。
图1所示,在问答任务中,作者将输入问题和短文表示成一个序列,其中,使用A嵌入表示问题,B嵌入表示短文。在微调的时候,作者引入一个start向量S,和一个end向量E,维数都为H。answer span的起始词word i的概率计算公式:
答案末尾词的概率表示原理一样。
位置i到位置j的候选span的分数定义如下:
并将满足j>i的最大得分的span最为预测结果。训练目标是正确的开始和结束位置的对数似然估计的和。
作者微调了3个epochs,学习率设置为5e-5,batch-size设置为32。
Table2 显示了顶级排行耪和结果。其中SQuAD排行耪中的公共系统描述没有最新的,并且允许使用任何公开数据训练各自的网络。
因此,作者在系统中使用适度的数据增强,首先对TriviaQA进行微调(Joshi et al., 2017),然后再对SQuAD进行微调。
We treat questions that do not have an answer as having an answer span with start and end at the [CLS] token. The probability space for the start and end answer span positions is extended to include the position of the [CLS] token. For prediction, we compare the score of the no-answer span: snull = S·C + E·C to the score of the best non-null span
s?i,j = maxj≥i S·Ti + E·Tj . We predict a non-null answer when s?i,j > snull + τ , where the threshold τ is selected on the dev set to maximize F1. We did not use TriviaQA data for this model. We fine-tuned for 2 epochs with a learning rate of 5e-5 and a batch size of 48.
The Situations With Adversarial Generations (SWAG)数据集包含113k个句子对完整示例,用于评估基于常识的推理。给定一个句子,任务是从四个选项中选择出最有可能是对的的continuation(延续/扩展)。
在微调的时候,作者构造了4个输入序列,每个包含给定句子A的序列和continuation(句子B)。引入的唯一特定于任务的参数是一个向量,它与[CLS]token做点积,得到每个选项的分数,该分数会通过一个softmax层来归一化。
作者微调的时候,使用了3个epochs,lr设置为2e-5,batch-size设置为16。Table4中有对应的结果,BERT在该领域的表现接近人类。
本节通过在BERT的各方面做消融实验,来理解相对重要的部分。
通过去掉NSP后,对比BERT的双向表征和Left-to-Right表征,作者得证明了有NSP更好,且双向表征更有效。
通过引入一个双向的LSTM,作者证明了BILSTM比Left-to-Right能得到更好的结果,但是仍然没有BERT的base版本效果好。
具体对比结果如图:
另外,关于ELMo那样的分别训练LTR和RTL的方式,作者也给出了其不如BERT的地方:
本节介绍模型大小对任务表现的影响。作者训练了一些不同层数、隐藏单元数、注意力头的BERT模型,但使用相同的超参数和训练过程。
Table6展示了对比结果。大模型带来更好的表现。
For example,
the largest Transformer explored in Vaswani et al. (2017) is (L=6, H=1024, A=16) with 100M parameters for the encoder, the largest Transformer we have found in the literature is (L=64, H=512, A=2) with 235M parameters (Al-Rfou et al., 2018). By contrast,
BERT(base) contains 110M parameters
BERT(large) contains 340M parameters.
本节作者最后给出的结论如下:
we hypothesize that when the model is fine-tuned directly on the downstream tasks and uses only a very small number of randomly initialized additional parameters, the taskspecific models can benefit from the larger, more expressive pre-trained representations even when downstream task data is very small.
大致意思是,通过微调,下游任务即使能提供的数据量非常小,依然可以利用预训练模型得到不错的训练效果。
相比于上面一直在说的fine-tuning的方式,feature-based的方式也有着其关键的优势。
首先,不是所有的任务都可以轻易的表示成Trasformer encoder 架构,所以会有需要添加一个基于特定任务的模型架构的需求。
其次,预先计算一次训练数据的昂贵表示,然后在此表示之上使用更便宜的模型运行许多实验,这对计算有很大的好处。
本节,作者在BERT的命名实体识别应用上比较了fine-tuning和feature-based方式。
在BERT的输入中,使用了一个保留大小写的单词模型,并包含了数据提供的最大文档上下文。按照标准实践,作者将其表示为标记任务,但在输出中不使用CRF层。作者使用第一个sub-token的表征,作为token-level的NER分类器的输入。
为了和fine-tuning方法做消融实验,作者以从没有微调任何参数的一层或多层提取activations的方式应用feature-based方法。这些上下文的嵌入用做一个随机初始化的两层768维BiLSTM的输入,然后送入分类器层。
Table 7显示了实验结果:
可以看到,feature-based方法中,拼接最后4个隐藏层的方式,可以达到96.1的F1分数,仅比BERT(base)少了0.3。
实验结果表明,BERT的2种应用方法都是有效的。
近来通过迁移学习改善模型学习的例子表明了丰富的,无监督的预训练是许多语言理解系统的重要组成部分。特别是,这些结果使得即使是低资源的任务也可以从深层单向架构中获益。
BERT的主要贡献是进一步将这些发现推广到深层双向架构,使得相同的预训练模型可以成功应对一组广泛的NLP任务。
作者在这里提供了预训练的样例。
Masked LM and the Masking Procedure 假设原句子是“my dog is hairy”,作者在3.1节 Task1中提到,会随机选择句子中15%的tokens位置进行mask,假设这里随机选到了第四个token位置要被mask掉,也就是对hairy进行mask,那么mask的过程可以描述如下:
上面的过程,需要结合训练过程的epochs来理解,每个epoch表示学完了一遍所有的样本,所以每个样本在多个epochs过程中是会重复输入到模型中的,知道了这个概念,上面的80%,10%,10%就好理解了,也就是说在某个样本每次喂给模型的时候,用[MASK]替换目标单词的概率是80%;用随机的单词替换目标单词的概率是10%;不改变目标单词的概率是10%。
有的介绍BERT的文章中,讲解MLM过程的时候,将这里的80%,10%,10%解释成替换原句子被随机选中的15%的tokens中的80%用[MASK]替换目标单词,10%用随机的单词替换目标单词,10%不改变目标单词。这个理解是不对的。
然后,作者在论文中谈到了采取上面的mask策略的好处。大致是说采用上面的策略后,Transformer encoder就不知道会让其预测哪个单词,或者说不知道哪个单词会被随机单词给替换掉,那么它就不得不保持每个输入token的一个上下文的表征分布(a distributional contextual representation)。也就是说如果模型学习到了要预测的单词是什么,那么就会丢失对上下文信息的学习,而如果模型训练过程中无法学习到哪个单词会被预测,那么就必须通过学习上下文的信息来判断出需要预测的单词,这样的模型才具有对句子的特征表示能力。另外,由于随机替换相对句子中所有tokens的发生概率只有1.5%(即15%的10%),所以并不会影响到模型的语言理解能力。对此,本论文的C.2节做了对此过程影响的评估。
相比标准的语言模型训练,masked LM在每个batch中仅对tokens的15%的部分进行预测,所以模型收敛需要更多的预训练步骤。C.1节演示了MLM比left-to-right模型(会对每个token进行预测)收敛的稍慢,但是学习效果的改善远远超过了增加的训练成本。
Next Sentence Prediction
”下个句子预测“的任务的例子:
Input = [CLS] the man went to [MASK] store [SEP]
he bought a gallon [MASK] milk [SEP]
Label = IsNext
Input = [CLS] the man [MASK] to the store [SEP]
penguin [MASK] are flight ##less birds [SEP]
Label = NotNext
本节首先介绍了下一句预测任务的样本获取策略,大致是从语料库文本中选取2个span,这里的span可以理解为一个完整话。然后,2个span分别对应句子A和句子B。其中,50%的情况下,句子B是句子A的下一句,而50%的情况下,B不是A的下一句。并且,句子A和B组合起来的长度要<=512个tokens。
然后介绍了LM的分词情况:
The LM masking is applied after WordPiece tokenization with a uniform masking rate of 15%, and no special consideration given to partial word pieces.?
作者预训练的时候采用batch-size=256,也就是说每个batch由256*512=128000个tokens,总共训练了1,000,000步,将近40个epochs,超过33亿个单词。梯度优化算法采用Adam,学习率=1e-4,β1=0.9,β2=0.999,0.01的L2权重衰减,学习率在首个10000步进行warmup【注释4】 ,然后进行线性衰减。作者在所有层使用了0.1概率的的dropout。在激活函数上,作者选择了gelu,而不是标准的relu,这个选择跟随了OpenAI GPT。The training loss is the sum of the mean masked LM likelihood and the mean next sentence prediction likelihood.(训练损失是masked掉的语言模型的似然均值与下一句预测的似然均值之和。)
BERT base模型在4块云TPU上训练(共16块TPU芯片)。BERT large在16块云TPU上训练(共64块TPU芯片)。每个预训练持续4天的时间完成。
由于注意力的计算复杂度是序列长度的平方,所以更长的序列所增加的成本是昂贵的。为了加速实验中的预训练过程,作者对90%的步骤使用128长度的序列预训练,然后用512长度的序列训练剩余的10%的步骤,以便学习到位置嵌入(positional embeddings)。
在fine-tuning的时候,模型的大多数超参数和预训练的时候是一样的,除了batch-size,learning rate和epochs。dropout的概率始终保持在0.1。优化超参数的值是特定于任务来做的,但是作者提到了下面的可能的值的范围,该范围内的值在跨任务上也工作的很好:
作者也观察了10万+的训练样本,超参数选择的敏感度远低于小数据集。Fine-tuning仍然非常快,所以简单粗暴的在上面的参数上运行一个穷举搜索来选择出可以让模型在开发集上表现最好的那些参数的方式也是可以接受的。
图3展示了这3个模型架构的对比:
除了MLM和NSP,BERT和GPT在训练的时候还有如下几处不同:
作者为了证明BERT模型是因为2个预训练任务和双向的Transformer才比其他模型表现更好,所以在5.1节中阐述了他们做的消融实验过程和结果。
如图4所示:
(a)和(b)是序列级别的任务;(c)和(d)是token级别的任务。
图中的E表示输入的词嵌入,Ti表示第i个token的上下文表征,[CLS]是分类输出的特定符号,[SEP]是分隔非连续token序列的特定符号。
以下是模型训练和评测使用的各种下游任务的数据集:
图5展示了在MNLI开发集上使用预训练了k步的模型进行微调后得到的准确度。
通过此图,就可以回答下面的问题了:
- BERT真的需要这么巨大的预训练量级吗(128,000 words/batch * 1000,000 steps)?
是的。相对于500k的steps,准确度能提高1.0%
- MLM预训练收敛速度比LTR慢吗?因为每个batch中只有15%的单词被预测,而不是所有单词都参与。
确实稍稍有些慢。但是准确度因此而立刻超过了LTR模型,所以是值得的。
之前说过,mask策略的目的是减轻预训练和微调之间的不匹配,因为[MASK]符号在微调的时候几乎不会出现。Table8展示了基于Fine-tune和基于Feature-based的方式下,不同的MASK策略对结果的影响:
可以看到,Feature-based的方式下,MASK造成的不匹配的影响更大,因为模型在训练的时候,特征提取层没有机会调整特征表示(因为被冻结了)。
在feature-based方法中,作者将BERT的最后4层输出拼接起来作为特征,因为这样的效果最好,具体见5.3节。
另外,我们还可以看到,fine-tuning方式在不同的mask策略下都具有惊人的鲁棒性。然而,如作者所料,完全使用MASK的策略在feature-based方式下应用到NER领域是有问题的。有趣的是,全部使用随机的策略也比第一行的策略差的多。
ok,本篇就这么多内容啦~,感谢阅读O(∩_∩)O。
标签:col 就是 大小写 ict ast 直接 ide 架构 有趣的
原文地址:https://www.cnblogs.com/anai/p/11645953.html