APP下载

探索中文预训练模型的混合粒度编码和IDF遮蔽

2024-03-26邵云帆孙天祥邱锡鹏

中文信息学报 2024年1期
关键词:词表词频语料

邵云帆,孙天祥,邱锡鹏

(复旦大学 计算机科学技术学院,上海 200433)

0 引言

不同于英语或其他能轻易区分字词的语言,中文句子中不包含显式的分词信息。在自然语言处理任务中,通常用两种粒度来编码和处理中文文本,词级别和字级别[1-3]。然而,如今大部分的中文预训练语言模型都采用字级别的细粒度编码方式。这会让句子被编码为很长的序列,增加模型的计算开销。而计算开销的增加,在预训练语言模型中更加明显。原因是预训练语言模型大都以Transformer作为主要模型架构。而Transformer的时间和空间复杂度都是O(L2),其中L是编码句子的长度。另一方面,词级别的粗粒度编码方式一般需要结合性能良好的中文分词器。当采用词级别编码的预训练语言模型被用于不同的数据集时,需要考虑所结合的中文分词器的领域迁移问题。当数据分布在模型应用领域和分词器的训练领域中的差异过大时,分词器的性能会有所下降,影响预训练语言模型的编码效果。更重要的是,词级别的粗粒度编码存在词典外词、数据稀疏以及错误传播等问题[4-6]。这些问题进一步阻碍了粗粒度编码方式在预训练语言模型中的直接使用。

尽管词级别编码方式有着众多不足,近年来,有许多工作显示词级别的粗粒度信息能够增强采用字级别编码的中文预训练语言模型。一种融合粗粒度信息的方式是将词级别的编码作为额外的特征输入模型[7-9]。这一方式往往需要引入额外的参数并增加模型的计算和存储开销。另一种融合方式是利用词级别的信息改进预训练任务。一些工作尝试改进预训练中的遮蔽掩码策略,将随机遮蔽改为遮蔽句子中的粗粒度信息,如遮蔽词、短语或者实体[1,10-11]。改进后的预训练任务能增强模型的性能,但是训练后的模型依旧用细粒度的字来编码文本。此外,在预训练时,粗粒度遮蔽的方法需要识别句子中的词、短语或实体,这通常需要一个高质量词典。在大规模预训练语料中,通常难以得到这样的词典,而用现有的词典可能会产生领域不匹配问题。

为了结合字级别和词级别编码的优点,探索高效的中文预训练模型编码粒度和编码方式。本文做出了以下改进:

首先,探索了基于混合粒度编码的中文预训练模型的有效性。在这一编码中,单字、词语和短语可以同时出现,共同编码文本。混合粒度编码的词表通过数据驱动的算法直接在预训练数据中得到[12]。相比之前的中文预训练语言模型,我们的模型编码效率更高,同时也避免了词表外词(OOV)问题,缓解了预定义词表与训练数据的领域不匹配问题。

另外,由于混合粒度的编码扩大了模型词表,可能需要用更有效率的方式预训练语言模型。为了加速预训练过程,我们提出了IDF遮蔽,一种基于词语逆向文档频率(IDF)信息[13]的遮蔽策略。词语的IDF信息直接从预训练语料中统计得到,以缓解数据分布不一致问题。在预训练时优先遮蔽高IDF的词语并让模型预测。高IDF的词语相比随机挑选的词出现概率更低,更加难以被预测。因此,这一预训练任务能鼓励模型捕捉更充分的上下文信息,从而加速模型的收敛。

我们在多个中文自然语言处理任务中进行了实验,证明了本文方法的有效性。在CLUE基准数据集上超越了BERT、RoBERTa等预训练模型。

1 方法

1.1 混合粒度编码

相比直接使用一个训练好的中文分词器,我们采用一元语言模型(Unigram Language Model)来获取混合粒度编码词表。更具体地,我们采用一个基于一元语言模型的无监督词表构建算法SentencePiece[14],在中文预训练语料上得到混合粒度的词表和每个词的出现概率。这一算法的使用让我们不用对语料进行分词处理,因此避免了因引入分词器而带来的数据分布不一致。

具体而言,我们基于句子中每个元素的出现概率都相互独立这一假设,使用一元语言模型建模语料中的句子。对于任意句子x,可以看成是词表中元素词元的(token)的序列x=(x1,x2,…,xN),因此,句子的出现概率可以表示为:

(1)

其中,N是句子中词元个数,p(xi)是词表中词元xi的出现概率,服从条件:

(2)

其中,V是预先给定的固定大小的词表。词表的构建对于词信息的利用至关重要。多粒度中文预训练模型一般通过在语料上统计词频得到高频词以构建词表[7-9, 15]。这些词表中的词一般质量较高,有清晰的词边界。然而,这些词表并未针对编码效率进行优化,若直接用于混合粒度编码,可能会出现编码后序列过长、词表过大、词表利用率低等问题。与词频统计方法不同的是,我们采用Kudo等[12]提出的算法,在大规模语料上迭代式地优化词表在整个数据集上的似然L,从而使得到的词表更适用于混合粒度编码。具体而言,基于一元语言模型,计算整个数据集的似然L,并进行优化,如式(3)所示。

(3)

其中,|D|为整个语料的句子数,S(X)是句子X的分词候选集合,P(x)的定义如式(1)。直接优化似然L计算量过大,因此这里使用EM算法并进行迭代优化。首先,算法根据语料统计得到一个大的初始词表,然后循环迭代式地逐步删除词表中的词,针对数据集似然L进行优化,直到词表大小符合预定义的阈值。具体的循环删词步骤为:

(1) 使用EM算法计算词表中每个词的概率p(xi),使数据集似然L最大。

(2) 针对每个词xi计算lossi,表示将词xi移除后似然L的减小量。

(3) 保留lossi较高的前μ%(一般取80%)的词。

表1 不同词表的对比

有了混合粒度的编码词表,就可以将任意句子编码为混合粒度的词元序列。具体而言,对于一段输入文本X,我们找到一串词元序列x,使得总概率最大,如式(4)所示。

(4)

其中,S(X)是句子X的分词候选集合。集合中的每一段分词序列都由词表中的词元组成,并且词表中包含了大量细粒度的词元,即汉字和字母。因此,在词表中不存在的词,会被拆分成字序列加以表示。这样我们的分词算法就可以避免词表外词(OOV)的问题。我们采用维特比算法[16]来得到概率最高的词元序列,避免遍历S(X)中的所有情况,减少了分词时所需的开销。

1.2 基于IDF的遮蔽策略

我们观察到,混合粒度编码增加了词表大小,这可能使得预训练语言模型需要训练更多的步数才能达到原有的效果。一方面,这会引入更多参数来表示词表中的词元向量。另一方面,基于齐夫定律,词表中的词元在数据集中呈现长尾分布,存在极少的高频词元和大量的低频词元[17]。这样高度偏斜的词频分布会导致数据稀疏的问题,即大量的词向量很少出现,也很难被训练。

为了更加系统地了解这一问题,我们在预训练语料上进行分词,并计算了每个词的词频和逆文档频率(IDF)[13]。对于一个词w,它的逆文档频率可以表示为:

(5)

其中,PD(w)是词w在文档中的出现概率,Nw是包含词w的文档数,N是语料中的总文档数。

正如图1中的结果所示,词频分布有着很大的方差,分布范围从101到108,并且大部分的词都只有很低的词频(小于103),显然这会导致数据稀疏问题。

图1 预训练语料中词的词频和逆文档频率(IDF)的分布图

为了缓解这一问题,一个简单直接的思路是在预训练时增加低频词的被遮蔽和被预测概率。然而,根据图1,拥有相似词频的词语可能有着差异很大的数据分布,而这一分布可以利用IDF来描述。如在图1中,我们展示了词频约为2 000时,不同词语的IDF值。其中高IDF的词可能是实体或名词,而带有低IDF值的词含有的语义信息较少。这说明IDF值相比词频而言,在筛选低频词时更加可靠。

因此,我们提出IDF遮蔽策略来加速预训练过程,并增强模型的表达能力。具体的处理流程如图2所示,我们首先在预训练语料中统计得到大规模词表以及对应的IDF值。在预训练时,我们首先利用现有分词器将句子分为由n个词组成的序列,然后从词表中得到每个出现词的IDF值,进一步从中取IDF值最大的k个词作为候选集;最后,在候选集中随机采样m个词作为遮蔽词。由于IDF词表一般远大于混合粒度的编码词表,遮蔽词可能横跨多个混合粒度词元序列。为了减少分词器的错误传播,我们选择能覆盖遮蔽词的连续混合粒度词元序列进行遮蔽,即以词粒度选择遮蔽范围,以模型编码粒度进行遮蔽。因为IDF词表的数据从预训练语料中得到,缓解了数据分布不一致的问题。另外,IDF遮蔽还增加了预训练任务的难度。相比随机遮蔽策略和简单的词级别遮蔽策略,IDF遮蔽策略让模型更加难以利用局部信息预测遮蔽位置的词,进而使得模型建模更丰富的、跨度更大的上下文信息,从而增强了模型的表达能力[11]。

图2 混合粒度编码的模型使用IDF遮蔽训练时的数据处理流程

2 实验设置

2.1 预训练设置

为了公平对比,我们使用大规模开源数据进行预训练,处理后数据集大小为13 GB,包含九百万个文档。对于混合粒度编码的词表,设置词表大小为6万,用SentencePiece在预训练语料中随机采样的2 000万个句子进行一元语言模型的训练。对于IDF遮蔽需要的低频词表和IDF值信息,我们首先用现有的中文分词器,将预训练语料分词,然后统计词频和IDF值,略去词频小于10的词。最后得到的IDF词表包含了大约100万个词。我们采用BERT-base架构,即12层的双向Transformer编码器,768维隐向量,前馈网络中间层维度为3 072,12个注意力头,每个注意力向量的维度为64。我们从头开始预训练,以公平对比,并使用Adam优化器训练模型100万步,最大句子长度为512,一个批次有384个句子。我们利用学习率先热身(Warmup)再衰减策略,学习率从零开始线性增加1万步,达到峰值10-4,然后线性衰减到零。遵循RoBERTa的超参数设置,我们将Adam的beta设为(0.9,0.98),参数衰减(Weight Decay)设为0.01。在预训练时,我们将遮蔽比例设为15%,并采用IDF遮蔽策略。其中,k为句子总词数的30%,m为句子总词数的15%。如当句子中包含512个词时,候选集大小k=154,遮蔽词数量m=77。整个预训练在8块英伟达RTX3090显卡(显存为24 GB)上完成,需要7天左右的时间。

2.2 下游任务设置

2.2.1 数据集

为了测试不同领域以及不同句长分布下模型的性能,我们选用以下数据集进行实验:

CLUE中文语言理解基准分类数据集[18]: 包含了6个数据集,语义相似度匹配数据集AFQMC,文本分类数据集IFLYTEK和TNEWS,自然语言推理数据集CMNLI,代词消歧数据集WSC,以及论文关键词匹配数据集CSL。与Zhang等相同,我们在TNEWS和CSL上使用了数据增强[8]。此外,我们还在情感分析数据集ChnSentiCorp[19],篇章级文本分类THUCNEWS[20]句对语义匹配数据集LCQMC[21]上测试了我们的模型。

对于已有分词标注的任务(如词性标注,命名实体识别,基于Span的阅读理解等),在使用混合粒度编码时,直接使用传统方式微调会由于分词不一致问题产生性能损失。针对这些任务,可以采用以下方法: ①改进解码方式,让模型预测词边界; ②直接使用字粒度编码微调; ③配合其他字粒度编码器同时使用;这些改进能缓解分词不一致问题,我们将混合粒度编码在这些任务中的扩展作为未来工作。

2.2.2 微调实验设置

对于基准模型,我们选择几个有代表性的主流中文预训练语言模型进行比较,以证明本文所提出的方法的有效性。为了与其他不同的编码方式进行比较,选取的模型有字级别、词级别以及多粒度融合字词的中文预训练语言模型:

BERT: 为了充分比较,我们选取几种不同的BERT实现: ①由谷歌发布的中文版BERT模型[22],在中文wiki上使用随机遮蔽训练,在本文中用BERT(Google)表示; ②由Cui等发布的基于整词遮蔽训练的BERT-wwm[2],在本文中简写为BERT; ③由Zhang和Li得到的词级别BERT[8],简称BERT(word)。

RoBERTa: 我们使用Cui等发布的RoBERTa-wwm-ext进行实验[2]。这一模型使用谷歌BERT初始化,在大规模语料上训练100万步得到。

AMBERT: 由Zhang等提出的多粒度编码模型[8],分别使用两个参数共享的编码器处理细粒度和粗粒度分词的文本。

LICHEE: 通过改进词嵌入层融合文本的多粒度信息的预训练方法[15]。作者将这一方法在不同结构的预训练模型上进行了应用。我们选用LICHEE-BERT进行对比。

Lattice-BERT: 通过改进注意力机制以编码Lattice结构的多粒度中文预训练模型[9]。

我们对所有模型都使用统一的微调流程,针对每个数据集,仅使用该数据集的训练集进行微调。在每个数据集上,都进行有限的网格搜索。其中,设置批量大小为{16,32},学习率为{1,2,3,5}×10-5,训练周期在除了WSC的数据集上取{5,8},在WSC上固定为80个周期。对于CLUE分类数据集,本文取开发集正确率最高的模型在测试集上进行预测,并汇报测试集的正确率。对于其他数据集,我们运行5次相同设置的实验,并同时汇报最佳和平均正确率。

3 实验结果与分析

3.1 主实验结果

我们汇报了基准模型以及我们的模型分别在CLUE分类数据测试集上的性能,结果列在表2中。对于其他数据集,我们的结果列在表3中,其中,“†”表示本文根据原论文复现后的结果,括号中的数字为平均值,括号前的数字为最高值。

表2 不同模型在CLUE基准测试中测试集上的正确率 (单位: %)

表3 不同模型在三个数据集上的正确率对比 (单位: %)

如表2和表3所示,混合粒度编码相比单一粒度的中文预训练模型,如BERT和RoBERTa等,有着明显的性能优势。如表2所示,而对比其他多粒度编码的预训练模型,如AMBERT、LICHEE-BERT和Lattice-BERT等,也有很强的竞争力。同时,混合粒度编码减短了输入长度,提高了模型推理效率。

3.2 混合粒度编码的有效性

混合粒度编码的一大优势是相比细粒度的编码,在保持模型的表达能力不变的同时,能够缩短编码序列的长度,并能减少模型的计算量。我们随机从数据集中抽取不同句子长度的文本,并计算这些文本用不同编码方式所需要的模型计算量,即FLOPs。结果如图3所示,混合粒度编码有效减少了计算开销,在长文本上效果尤为明显。

图3 字级别编码方式(BERT)和混合粒度编码(Ours)在不同长度下的相对计算开销比较

我们进一步在不同数据集上对比不同编码方式的平均编码长度,并分别记录推理时间,结果如表4所示,相比字粒度编码,混合粒度编码缩小了文本的平均编码长度,并加快了推理速度。

表4 不同编码方式在不同数据集上的平均编码长度和推理时间比较

为了进一步比较不同的编码方式,我们去除了IDF遮蔽,使用和BERT相同的整词遮蔽进行训练和比较。如表5所示,我们的模型“Our BERT(mixed)”就编码效率而言优于同等数据量训练的BERT模型。为了公平比较,用同样的数据集和超参复现了BERT,结果见“Our BERT(char)”。可以看到IDF遮蔽相比整词遮蔽能同时为字级别和混合粒度编码的预训练模型带来性能提升。当IDF遮蔽配合混合粒度编码时,所带来的提升更加明显。

表5 不同编码方式和遮蔽方式在CLUE基准测试中验证集上的正确率(除特殊标明模型使用整词遮蔽训练) (单位: %)

3.3 IDF遮蔽的有效性

为了更进一步地证明IDF遮蔽策略的有效性,我们分别使用IDF遮蔽策略以及整词遮蔽策略预训练了语言模型,最终结果见表5。配合混合粒度编码,我们的模型最终能在CLUE验证集上取得76.13%的平均性能。而单独在字级别预训练模型上使用IDF遮蔽,增强了预训练任务的难度,从而也增强了模型的性能(表5)。

我们选取出优化了不同步数的模型在TNEWS数据集上进行微调。结果如图4所示,当训练步数相同时,使用了IDF遮蔽策略的模型的下游任务性能比整词遮蔽策略优化的模型要好,并且随着训练步数的增加IDF遮蔽策略将持续地提升模型的性能,在训练1M步后依然保持了性能增长趋势,并且大幅超过了整词遮蔽策略训练的模型。

图4 使用不同遮蔽方式训练的模型在TNEWS验证集上的性能随预训练步数的变化情况

为了更细致地比较IDF遮蔽策略和整词遮蔽策略的不同,我们随机采样了约2 000万个词的预训练语料(约200 MB),分别使用整词遮蔽和IDF遮蔽选择遮蔽词,并将被遮蔽的词数按词频进行统计,结果如图5所示。相比整词遮蔽,IDF遮蔽倾向于选择词频在102~106的中低频词进行掩码,而显著减少高频词(词频高于108)的掩码次数。如图5所示,IDF遮蔽改变了不同词频的词被遮蔽的概率,而非完全忽略高频词。因为IDF遮蔽仅在句内进行IDF排序和选择,而语料中存在很多仅由高频词组成的句子,这时IDF遮蔽从句中选择的遮蔽词(其在句内排序IDF很高)在整个语料上IDF很低,属于高频词。

图5 不同遮蔽方式中被遮掩词在语料中的词频分布

4 相关工作

4.1 多种粒度编码的中文预训练模型

现存的中文预训练语言模型通常将句子以字序列的方式编码。然而,这会使得长句子难以被表示,会产生很大的计算开销。同时,这也忽略了中文丰富的粗粒度信息。为了融合粗粒度信息到中文预训练语言模型中,Zhang等提出了使用两个参数共享的编码器分别建模粗粒度和细粒度的信息[8]。而Diao等提出使用一个额外的编码器单独建模N元(N-Gram)信息,并逐层融合到细粒度编码的预训练语言模型中[7]。然而,这些额外引入的编码器会引入大量的参数,额外增加了计算和存储开销。Li等将文本进行细粒度编码的同时,加入了Lattice信息作为模型的输入,并提出了表示Lattice结构的相对位置编码,使得模型能同时建模多种粒度的文本[9]。然而,Li等的模型结构使得输入序列变长,相对位置编码也存在较大的计算开销,大大增加了模型的计算量。相比之前的工作,我们提出的混合粒度编码能将句子表示为较短的序列,增加了模型的编码效率。

4.2 词信息增强的遮蔽语言建模

相比仅使用随机遮蔽的预训练任务,有一系列工作显示,遮蔽文本中的词、短语和实体进行训练,将会增强预训练模型的性能[1, 9-11]。例如,谷歌在BERT的基础上,使用整词遮蔽训练了BERT-wwm。Joshi等人提出SpanBERT,随机遮蔽连续的词元序列,从而进一步增加任务难度[10-12]。ERNIE为了融合知识到模型中,提出遮蔽句子中的实体。针对融合了Lattice信息的模型,Li等提出先将文本分成几个互相没有Lattice信息连边的几个分割,然后以分割为单元遮蔽[9]。这样的模型无法直接利用相连的Lattice信息进行预测,增加了预测难度。ERNIE-Gram提出在训练细粒度编码的语言模型时,可以同时让模型预测文本中的粗粒度信息,从而增强模型的性能[22]。这样模型仍然建模细粒度分词的文本,在预训练时使用整词遮蔽后,模型需同时预测被遮蔽词以及词的细粒度信息(词元序列)。然而,这些方法在遮蔽前往往需要得到文本中的词语或实体等粗粒度信息。这时一般需要一个预先给定的大规模词库或实体库。因此,预训练语料和词库之间可能会出现数据分布不一致的问题。并且,这些方法在遮蔽时没有考虑到数据稀疏的问题,低频词的出现相对较少且比较稀疏。相比之前的方法,IDF遮蔽策略使用了在预训练语料上得到的统计信息,并且让模型重点学习文本中的稀有词,从而缓解了数据不一致和数据稀疏的问题,更进一步地增强了模型。

5 总结与展望

本文探索了中文预训练中应用混合粒度编码的可能性。相比之前中文预训练模型广泛采用的细粒度编码,我们提出的混合粒度编码有效提升了编码效率。而相比词级别等粗粒度的编码方式,本文的方法有效缓解了词表外词(OOV)以及数据稀疏等问题。搭配上所提出的IDF遮蔽策略,我们预训练的混合粒度编码语言模型在多个数据集上取得了有竞争力的性能,并且减少了大量模型计算量。

未来工作包括混合粒度编码应用范围的拓展以及预训练遮蔽策略的进一步改进。混合粒度编码能够明显提升编码器的编码效率,但对于需要细粒度分词的下游任务不够友好。未来可以将混合粒度编码器与细粒度的解码器相结合,进一步扩展模型的应用深度和广度。另一方面,IDF遮蔽策略根据词频信息调节了不同词汇的遮蔽频率,未来可以基于更丰富的数据集和其他先验信息更系统地选择遮蔽词和遮蔽方式,以加快模型的预训练过程并提升训练效果。

猜你喜欢

词表词频语料
基于词频分析法的社区公园归属感营建要素研究
A Chinese-English List of the Sports Programmes in Winter Olympics 冬奥会项目名称汉英对照词表
基于语料调查的“连……都(也)……”出现的语义背景分析
叙词表与其他词表的互操作标准
华语电影作为真实语料在翻译教学中的应用
词频,一部隐秘的历史
云存储中支持词频和用户喜好的密文模糊检索
《苗防备览》中的湘西语料
国内外语用学实证研究比较:语料类型与收集方法
以关键词词频法透视《大学图书馆学报》学术研究特色