王永鹏,周晓磊,,马慧敏,曹吉龙
1(中国科学院 沈阳计算技术研究所,沈阳 110168)
2(中国科学院大学,北京 100049)
3(东软集团股份有限公司,沈阳 110179)
4(中国医科大学附属第四医院,沈阳 110032)
线下医院排队时间长,看病慢已经是每个患者心中的痛点.现在虽然几乎每个医院都有线上预约挂号,线下看病,或者线上直接问诊等功能但是还需要患者根据自己的病情特征自己选择科室,进而找到医生,但是这种方式显示没有将互联网医院数据得到充分的利用.因而利用深度学习的技术解决人们快速的线上就诊成为急切的问题.
医患IM 页作为最大的流量和服务入口,其中聊天文本信息覆盖了疾病名称、症状、药品名称等多种命名实体,所以准确的刻画Query和Context 之间的深度语义相关性至关重要,还有不同患者在描述症状上字面相差巨大,比如感冒和头痛、鼻子堵塞、流鼻涕、发烧、身体发冷等词之间的字面意思相差非常大,但是他们却是和呼吸内科是语义相关的.在这种场景下用户希望在不同场景下通过输入文字来获取自己想要的服务,这就需要一个强大的模型.
这其中有4个痛点:第1个是患者描述病情信息特征稀疏问题,模型很难学习到准确的语义信息.第2个是基于深度Transformer的模型虽然效果好,但是推理速度慢,很难应用到实时的生产环境.第3个是文本医患聊天中命名实体信息多而复杂.第4个是不同患者描述字面信息差别大.为了解决这几个痛点问题,本文提出了自己设计搭建的DNNBERT 算法模型.
这样的设计灵感来源是用户的信息特征可能随时都会横向增加,来弥补数据稀疏问题,例如实现智能分诊仅仅依靠患者简单粗糙的病情描述是比较困难的,还需要考虑患者年龄,性别,历史疾病等横向的信息,因此设计出DNNBERT,其中DNN 部分可以处理用户附加特征,基于BERT 改进的ALBERT[1]模型可以充分发挥其强大的语义理解能力,所以DNNBERT,不仅解决了文本向量信息稀疏的问题,还解决了BERT 模型训练速度慢的问题,将深层Transformer 模型应用于生产提供了新思路.
自然语言处理中文本分类问题,最重要的就是文本表示,就是如何提取出文本中原本的语义信息,最早期的二分类学习模型采用one-hot 编码,仅单纯地将文本表示为算法可处理的结构化向量,参数量也会非常大.CNN 采用共享卷积核方式,优化了参数量,并且深层次的网络抽取信息更加丰富,表达效果也更好,但CNN的输入和输出都是相互独立的,并没有考虑到文本中字前后的序列问题.RNN 引入了“记忆”的概念,引入了时间序列模型,输出依赖于输入和“记忆”,RNN 善于学习顺序建模任务但在提取特征的时候不能以并行的方式进行.双向RNN 采用双向编码特征拼接的方式,让当前的输出不仅依赖于输入和之前的序列元素,还依赖于之后的序列元素.深层双向RNN 在双向RNN的基础上改进,在每个时间点设定多层网络结构.LSTM[2]与RNN的基本结构相似,区别是它提出了一种“记忆细胞”的概念,该记的信息会一直传递,不该记得会被“门”截断,解决RNN 远距离的信息丧失的问题.GRU[3]是LSTM的变种,将忘记门和输入门合成了一个单一的更新门,混合了细胞状态和隐藏状态和其他一些改动.它比标准LSTM 更简单.Word2Vec[4]将文本的表示通过词向量的表示方法,把文本数据从高纬度稀疏的神经网络难处理的方式,变成了类似图像、语言的连续稠密数据.Google的词向量文章中涉及的两个模型CBOW (上下文来预测当前词)和Skipgram (当前词预测上下文).ELMo[5]来自于语言模型的词向量表示,也是利用了深度上下文单词表征,该模型的好处是:(1)能够处理单词用法中的复杂特性(比如句法和语义);(2)这些用法在不同的语言上下文中如何变化(比如为词的多义性建模).GPT[6]这种模型之所以效果好是因为在每个新单词产生后,该单词就被添加在之前生成的单词序列后面,这个序列会成为模型下一步的新输入.这种机制叫做自回归(auto-regression),同时也是令RNN 模型效果拔群的重要思想.而BERT[7]虽然没有使用自回归机制,但 BERT 获得了结合单词前后的上下文信息的能力,从而取得了更好的效果.XLNet[8]使用了自回归,并且引入了一种能够同时兼顾前后的上下文信息的方法.ALBERT 相比BERT-LARGE,在推理速度上有了巨大的改进,具体的创新部分有3个:(1)将embedding的参数进行了因式分解;(2)跨层的参数共享;(3)抛弃了原来的NSP 任务,现在使用SOP 任务.上面这些模型其实在文本分类效果上都具有巨大的意义的提高,但是同时他们都具有超大的参数量,从而导致在生产应用上显得有些笨重.本文提出的DNNBERT 就是为了解决上述问题.
本文的研究主要致力于自然语言处理中语义理解方向,研究内容为深层Transformer 网络结构.与RNN相比,Transformer 语义特征提取能力更强,具备长距离特征捕获能力,基于注意力的深层Transformer 模型[9]的成功启发了大量后续工作.类似于智能分诊这样的短文本(信息稀疏)分类场景下,学术界也出现了很多优秀的研究成果,例如融合更多外部知识的百度ERNIE[10],K-BERT[11].优化预训练目标的ER-NIE2.0[12],Ro-BERTa[13],SpanBERT[14],StructBERT[15]等.优化模型结构或者训练方式的ALBERT.关于预训练模型的各种后续工作,可以参考复旦大学邱锡鹏老师最近的综述[16].
基于预训练好的BERT 模型可以支持多种下游NLP 任务.BERT 在下游任务中的应用主要有两种方式:即Feature-based和Finetune-based.其中Featurebased 方法将BERT 作为文本编码器获取文本表示向量,从而完成文本相似度计算、向量召回等任务.而Finetune-based 方法是在预训练模型的基础上,使用具体任务的部分训练数据进行训练,从而针对性地修正预训练阶段获得的网络参数.该方法更为主流,在大多数任务上效果也更好.
由于BERT 家族类模型在NLP 任务上的显著优势,一些研究工作开始将BERT 应用于复杂场景的文本分类任务上.清华大学Qiao 等人[17]详细对比了Feature-based和Finetune-based 两种应用方式在文本段落排序(passage ranking)中的效果,分析说明了BERT 如何在它的转换层中的查询文档词条之间分配注意力,以及如何在释义词条之间选择语义匹配.滑铁卢大学Jimmy Lin 团队[18]针对分类排序任务提出了基于Pointwise和Pairwise 训练目标的MonoBERT和DuoBERT 模型.此外,该团队提出融合基于BERT的Query-Doc 相关性和Query-Sentence 相关性来优化分类结果排序任务的方案.为了优化文本分类性能和效果,Bing 广告团队提出一种双塔结构的TwinBERT[19]分别编码Query和Context 文本.2019年10月,Google在其官方博客中介绍了BERT 在Google 搜索排序场景的应用,BERT 强大的语义理解能力改善了约10%的搜索结果,除了英文网页,Google 也正在基于BERT优化其他语言的搜索结果.
本文在这些前辈的思想和基础上,针对医患聊天这样的特定场景,提出了双塔结构的知识融合模型DNNBERT,它的创新点主要有:可以不断的横向实现知识融合,在预训练阶段引入患者大量结构化信息,例如性别,年龄,历史疾病等标签信息,弥补Query 文本信息的不足,强化语义匹配效果.极大提高了模型运行的速度,不同于BERT-LARGE,本文在融合模型时选择了ALBERT 模型和DNN 进行融合,DNNBERT 可以实现相对于BERT-LARGE,速度提升1.7 倍.
随着智能化的发展,越来越多的患者问诊就医只想通过一句话描述来快速的匹配到科室就医甚至直接获取自己想要的医生,药品,病情诊断等信息.但是用户的文本描述是多种多样的,既有药品名称,疾病名称,病情症状名称,甚至同一种疾病治疗还有不同的药品名,不同的症状描述,不同的患者有不同的病情描述.还有患者的基本特征,包括年龄,性别,历史疾病,最近浏览科室、最近浏览过的医生、最近问诊过的科室最近浏览过的医生、最近一次购药明细、最近病例描述等特征对于分科室也是至关重要的.要将这么多维的信息来分类匹配到具体的科室,准确的刻画数据就变得非常重要.本文提出DNNBERT 模型,在特征表示上采用固定长度患者特征拼接患者文本描述的方式进行Embedding.模型网络设计分为两个网络,DNN 网络负责用户特征的信息抽取,Transformer 网络来学习文本描述.将学习到的结果拼接链接到一个池化层,再用Softmax 进行分类,模型架构图如图1所示.
图1 DNNBERT 模型结构图
从图1中可以看到,自上而下,从左到右,DNNBERT模型主要由神经网络和ALBERT 模型两部分排列进行处理,类似于双塔并列,所以称为双塔结构,设计的初衷是并列的两个模型根据自身模型的特点来处理不同特征的文本,DNN 模型对于文本的学习能力强,像性别,年龄这样的特征数据没有太多的深度语义,所以采用DNN是不错的选择,但是患者病情描述文本语义就比较复杂,需要基于注意力的Transformer来学习其中的语义,所以采用当前效果较好,速度较快的ALBERT,DNN和ALBERT 两者根据自身的优势来分别对文本进行学习,最后将DNN和ALBERT 模型学习的结果进行拼接,从而DNNBERT 输出的结果是模型结合了两个模型分别学习处理过得高度抽象语义信息,实现了DNN和Transformer 间知识补充和融合.下面分别阐述模型主要模块的具体实现细节.
图1中,从上至下,第2 层左侧的神经网络模型主要学习患者相关基本信息,例如:性别(两种可能2 位进行编码)、年龄(11 种可能11 位编码,1 至10 岁为一类,11 至20 岁为一类,一次类推)、最近一次访问的科室(15 种可能15 位编码)、最近一次问诊的医生所属科室(15 种可能15 位编码)、对最近一次问诊的医生的评价(4 种可能4 位编码),然后进行最大最小归一化,拼接成feature 总共64 维,作为模型输入,然后连接DNN 层(共两个隐藏层:第一个隐藏层64个神经元,该层使用ReLU 激活函数;第二个隐藏层128个神经元),第三层输出层为16个神经元输出层为16 维的特征向量,作为DNN 特征提取的结果将和ALBERT模型的拼接一起作为连接层的输入.
图1中,从上至下,第2 层右侧的模型为ALBERT模型,该模型参数量小,速度快,用于学习患者病情描述文本的语义.
ALBERT 采用了两种参数简化技术,消除了缩放预先训练模型的主要障碍.第一种是因子化嵌入参数化.通过将大的词汇嵌入矩阵分解为两个小矩阵,我们将隐藏层的大小与词汇嵌入的大小分开.这种分离使得在不显著增加词汇表嵌入的参数大小的情况下更容易增加隐藏的大小.第二种技术是跨层参数共享.该技术可防止参数随网络深度的增加而增大.这两种技术在不严重影响性能的情况下显著减少了BERT的参数数目,从而提高了参数效率.参数简约技术也可以作为一种正则化的形式来稳定训练并有助于泛化.为了进一步提高ALBERT的性能,我们还引入了一种自监督的句子顺序预测损失(SOP).SOP 主要关注句子间的连贯性,旨在解决原BERT中提出的下一句预测(NSP)损失的无效性.
2.2.1 BERT 模型
BERT 根据名称就可以知道,其核心是基于Transformer 结构的,Transformer是一个端到端训练的网络结构,即输入和输出均为一个序列,Transformer是一个由Encoder和Decoder 组成的网络结构,其中最重要的是在RNN的基础上加入了注意力机制.Encoder 由6个相同的layer 组成.每个layer 由两个sublayer 组成,分别是multiHead self-attention mechanism和fully connected feedforward network.其中每个sublayer 都加了residual connection和normalization,multiHead attention 则是通过h个不同的线性变换对Q,K,V进行投影,最后将不同的attention 结果拼接起来.
Transformer中最重要的两个结构是Encoder和Decoder 结构,我们先来看看Encoder 结构的组成部分,如图2所示.
图2 Encoder内部结构示意图
如图2所示,Transformer中没有采用传统的CNN和RNN,整个网络结构主要是由self-Attenion和feed forward neural network 组成.在经典的BERT 模型中,Transformer 结构主要由6 层的Encoded和6 层的Decoder 组成.
输入是文本的Embedding 表示,并且在输入的Embedding 上加入了位置信息,将结果输入自注意力层进行权重计算学习,将计算的输出和自注意力的输入相加和归一化操作,采用Attention 机制的原因是考虑到RNN(或者LSTM,GRU 等)的计算限制为是顺序的,也就是说RNN 相关算法只能从左向右依次计算或者从右向左依次计算,这种机制带来了两个问题:
时间片t的计算依赖t–1 时刻的计算结果,这样限制了模型的并行能力;
顺序计算的过程中信息会丢失,尽管LSTM 等门机制的结构一定程度上缓解了长期依赖的问题,但是对于特别长期的依赖现象,LSTM 依旧无能为力.
Transformer的提出解决了上面两个问题,首先它使用了Attention 机制,将序列中的任意两个位置之间的距离是缩小为一个常量;其次它不是类似RNN的顺序结构,因此具有更好的并行性.
再将注意力输出的结果接入前馈神经网络,进行学习输出Embedding.
2.2.2 Attention的计算过程
式中,dk的含义是每个字的Q向量的维度,将Q和K向量的乘积结果进行Softmax归一化和Value 向量相乘,这样计算结束之后,就得到了每个字的注意力权重,而后将上式中的每个结果进行累加,就得到每个字的表示,此时每个字已经融入了句子中其他字的信息进去,是一个表达能力非常强的向量表示.
多头注意力(multi-head attention)是利用多个查询组成的矩阵Q,来平行地计算从输入信息中选取多个信息.每个注意力关注输入信息的不同部分,然后再进行拼接,这样就可以从指代消解,位置等不同维度来综合的识别语义信息,计算公式如下:
在BERT 模型中,多头数量是一个超参数,可以进行配置.
如图1所示,其中全连接层部分主要思路是将上侧DNN和ALBERT 模型的输出拼接,一方面进行联合训练学习,抽象提取两部分模型的组合特征;另一方面将上侧两部分特征进行压缩,输出为16 维特征,目的是减少特征维度,提高线上模型的运行性能.该部分DNN 模型共3个隐藏层:第1个隐藏层256个神经元(DNN和ALBERT 模型拼接结果),该层使用ReLU 激活函数;第2个隐藏层128个神经元,激活函数为ReLU;第3个隐藏层64个神经元,激活函数为Softmax,输出层为16 维分类的结果.
实验数据中主要列举了科室类以及每个科室类别对应的数据条数,以及数据的分割,分为训练集、验证集、测试集3 类.实验数据分布如表1.
表1 实验数据分布表
本文实验使用的语料库来自京东互联网医院的患者就诊数据,此次实验数据总条数约为73 万条,科室分类数为15个类别,分别为内科,外科,妇产科,儿科,精神心理科,肿瘤科,中医科,骨科,眼科,皮肤性病科,耳鼻喉头颈外科,口腔科,男科,整形美容科,其他科.本次实验将总数按照8:2的比例分为训练集,测试集.对模型迭代10000 次进行训练学习.并且在模型学习完毕后,将数据随机打散分为五份数据,分别在A、B、C、D、E 五份样本数据的基础上和TextCNN[20]、TextCNN_Att、FastText[21]、BERT-LARGE、ALBERT 等BERT 家族的模型进行了对比,实验证明,基于联合训练的模型DNNBERT,要比其他模型更容易学习到语义信息,总体准确性更好.
在进行模型评价的时候,作者采用的是F1 Score,因为它更加能反映出模型的健稳性,它被定义为模型精度和召回率的调和平均值,因此,如果你想在精确度和召回率之间寻求平衡,F1 Score是一个更好的衡量标准.
在分类问题中,我们都会用到混淆矩阵[22]来计算和评估模型的性能,如表2所示.
表2 分类结果的混淆矩阵
1)精确度.精确度给出了所有预测为正的结果中正确识别为正例的分数:
2)召回率.召回率给出模型正确识别为正例的分数:
3)F1,可以理解为模型在召回和精准率之间做了调和平均:
因此,为了想在精确度和召回率之间寻求平衡的评价指标,F1 分数是一个更好的衡量标准.
本次实验为了对比DNNBERT 模型的优劣性,分别和TextCNN,TextCNN_Att,ALBERT,FastText,BERT-LARGE,几种模型进行了对比,表3是DNNBERT模型的参数设置.
表3 DNNBERT 模型参数设置
表3中hidden_ dropout_prob 表示隐层dropout 率,hidden_size 表示隐藏层神经元数,num_hidden_layers 表示Transformer encoder中的隐藏层数,num_attenti on_heads 表示multi-head attention的head 数 intermediate_size 表示ALBERT encoder的中间隐层神经元数(例如feed-forward layer),hidd -en_act:隐藏层所采用的激活函数,embedding _ize 表示输入向量的大小,短补长切.
实验采用的机器参数Linux 系统,CPU 核数为8 核,内存大小为40 GB,一张GPU 卡,batchSize 表示训练时每批数据的数量,每批次数据量为1000 条,epoch 表示迭代训练的次数,训练10000 次,learning_rate 学习率表示模型学习的准确率.
本文先后做了5 组实验,分别为A 组、B 组、C 组、D 组、E 组.在进行模型对比实验时,DNNBERT,TextCNN_Att,ALBERT,TextCNN,FastText 等5个模型的参数不变,A,B,C,D,E 五组的数据也不变,评价指标主要采用了综合精确率和召回率的F1 值进行对模型进度评估,在相同实验环境下,5 组实验F1 Score精度对比结果如表4所示.
图3是对应的表4数据的可视化,即每个模型在每组实验数据集上的F1 Score的可视化展示.
表4 模型精度对比表
我们选择选择的模型评价标准为F1 Score,横坐标1,2,3,4,5 分别表示5 组实验,纵坐标分别表示模型的F1 值,范围从0 到1,从图3中可以得出以下结论.
图3 模型精度对比图
(1)模型的精度随着训练数据量的增加而正比提高,在第一次实验中,可以观察到模型的精度层次不齐,随着后面多次实验,精度逐渐趋于稳定.
(2)DNNBERT 模型随着训练次数的增加,效果相比其他对比模型,精度领先于其他模型.
(3)在经过5 次实验之后,DNNBERT 模型的精度最高,其次是TextCNN_Att 模型,即DNNBERT 相比TextCNN_Att,精度提高了0.12,分数最低的是FastText模型,F1 值为0.67,DNNBERT 相比FastText,精度提高了0.23.
综上,我们可以得出结论,本文提出的联合知识的融合训练模型,在处理短文本分类场景时,十分具有优越性,同时也说明了集成训练模型的优越性,成为了只能分诊场景最优的解决方案.
本文在解决中文短文本分类的问题中,提出了一种基于ALBERT 模型和DNN 网络的双塔模型的知识融合训练模型DNNBERT,并与TextCNN,ALBERT,TextCNN_Att,FastText 模型进行对比,先后做了A 组、B 组、C 组、D 组、E 组5 组实验,对比实验时的测试数据量是总数据的1/5.5 组实验测试数据总数为73823,平均分为5 组,每组14764 条.实验结果表明,融合知识的联合训练模型DNNBERT 模型在科室分类中效果好于CNN (TextCNN,TextCNN_Att,FastText)和ALBERT.下一步将对模型中文本编码的长度与神经网络隐藏层的个数和预测结果间的关系进行研究,来找出最优的模型参数,并且也会让模型不断的融合更多的外部知识,提高模型的泛化性.除了模型的精度提升之外,还会在模型的速度方面去提升,后期希望引入蒸馏,剪枝等技术将自己的模型不但从精度方面提升到最强,也希望训练的速度足够快,从而可以适用于工业生产.
致谢
特别感谢京东健康提供实验所需相关的数据,感谢公司领导的大力支持.