作者: 高开远
学校: 上海交通大学
研究方向: 自然语言处理
写在前面
去年NLP领域最火的莫过于BERT了,得益于数据规模和计算力的提升,BERT在大会规模语料上预训练(Masked Language Model + Next Sentence Prediction)之后可以很好地从训练语料中捕获丰富的语义信息,对各项任务疯狂屠榜。
我们在对BERT进行微调之后可以很好地适用到自己的任务上,具体可以参考之前一篇BERT简单应用:BERT模型实战之多文本分类(附源码)。
如果想深入了解BERT的运行机制,就需要去仔细地研读一下BERT的源码啦,其实也不是很难理解:BERT源码分析PART I。
在了解了BERT的发展史【NLP大杀器BERT模型解读】之后,今天这篇文章我们来看看在BERT提出大半年之后,又有哪些基于BERT的有趣的研究。
√ ERNIE from Baidu
√ ERNIE from THU
1、ERNIE: Enhanced Representation through Knowledge Integration(Baidu/ACL2019)
百度提出的ERNIE模型主要是针对BERT在中文NLP任务中表现不够好提出的改进。我们知道,对于中文,bert使用的基于字的处理,在mask时掩盖的也仅仅是一个单字,举个栗子:
我在上海交通大学玩泥巴-------> 我 在 上 海 [mask] 交 通 【mask】学 玩 【mask】 巴。
作者们认为通过这种方式学习到的模型能很简单地推测出字搭配,但是并不会学习到短语或者实体的语义信息, 比如上述中的【上海交通大学】。于是文章提出一种知识集成的BERT模型,别称ERNIE。ERNIE模型在BERT的基础上,加入了海量语料中的实体、短语等先验语义知识,建模真实世界的语义关系。
在具体模型的构建上,也是使用的Transformer作为特征抽取器。这里如果对于特征抽取不是很熟悉的同学,强烈推荐张俊林老师的" 放弃幻想,全面拥抱Transformer: 自然语言处理三大特征抽取器(CNN/RNN/TF)比较 "。
那么怎么样才能使得模型学习到文本中蕴含的潜在知识呢?不是直接将知识向量直接丢进模型,而是在训练时将短语、实体等先验知识进行mask,强迫模型对其进行建模,学习它们的语义表示。
具体来说, ERNIE采用三种masking策略:
-
Basic-Level Masking:跟bert一样对单字进行mask,很难学习到高层次的语义信息;
-
Phrase-Level Masking:输入仍然是单字级别的,mask连续短语;
-
Entity-Level Masking:首先进行实体识别,然后将识别出的实体进行mask。
经过上述mask训练后,短语信息就会融入到word embedding中了
此外,为了更好地建模真实世界的语义关系,ERNIE预训练的语料引入了多源数据知识,包括了中文维基百科,百度百科,百度新闻和百度贴吧(可用于对话训练)。
关于论文后面的试验就不再赘述。
reference:
-
如何评价百度新发布的NLP预训练模型ERNIE?
-
中文任务全面超越 BERT:百度正式发布NLP预训练模型ERNIE
-
官方源码
2、ERNIE: Enhanced Language Representation with Informative Entities(THU/ACL2019)
本文的工作也是属于对BERT锦上添花,将知识图谱的一些结构化信息融入到BERT中,使其更好地对真实世界进行语义建模。也就是说,原始的bert模型只是机械化地去学习语言相关的“合理性”,而并学习不到语言之间的语义联系,打个比喻,就比如掉包xia只会掉包,而不懂每个包里面具体是什么含义。于是,作者们的工作就是如何将这些额外的知识告诉bert模型,而让它更好地适用于NLP任务。
但是要将外部知识融入到模型中,又存在两个问题:
-
Structured Knowledge Encoding:对于给定的文本,如何高效地抽取并编码对应的知识图谱事实;
-
Heterogeneous Information Fusion:语言表征的预训练过程和知识表征过程有很大的不同,它们会产生两个独立的向量空间。因此,如何设计一个特殊的预训练目标,以融合词汇、句法和知识信息又是另外一个难题。
为此,作者们提出了ERNIE模型,同时在大规模语料库和知识图谱上预训练语言模型:
-
抽取+编码知识信息:识别文本中的实体,并将这些实体与知识图谱中已存在的实体进行实体对齐,具体做法是采用知识嵌入算法(如TransE),并将得到的entity embedding作为ERNIE模型的输入。基于文本和知识图谱的对齐,ERNIE 将知识模块的实体表征整合到语义模块的隐藏层中。
-
语言模型训练:在训练语言模型时,除了采用bert的MLM和NSP,另外随机mask掉了一些实体并要求模型从知识图谱中找出正确的实体进行对齐(这一点跟baidu的entity-masking有点像)。
okay,接下来看看模型到底长啥样?
如上图,整个模型主要由两个子模块组成:
-
底层的 textual encoder (T-Encoder) ,用于提取输入的基础词法和句法信息,N个;
-
高层的 knowledgeable encoder (K-Encoder) , 用于将外部的知识图谱的信息融入到模型中,M个。
knowledgeable encoder
这里T-encooder跟bert一样就不再赘述,主要是将文本输入的三个embedding加和后送入双向Transformer提取词法和句法信息:
K-encoder中的模型称为aggregator,输入分为两部分:
接着利用multi-head self-attention对文本和实体分别处理:
然后就是将实体信息和文本信息进行融合,实体对齐函数为
:
上述过程就是一个aggregator的操作,整个K-encoder会叠加M个这样的block:
最终的输出为最顶层的Aggregator的token embedding和entity embedding。
改进的预训练
除了跟bert一样的MLM和NSP预训练任务,本文还提出了另外一种适用于信息融合的预训练方式, denoising entity auto-encoder (dEA). 跟baidu的还是有点不一样,这里是有对齐后的entity sequence输入的,而百度的是直接去学习entity embedding。dEA 的目的就是要求模型能够根据给定的实体序列和文本序列来预测对应的实体:
微调
为了使得模型可以更广泛地适用于不同的NLP任务,作者也学习BERT设计了不同的特殊的token:
-
【CLS】:该token含有句子信息的表示,可适用于一般任务
-
【HD】和【TL】:该token表示关系分类任务中的头实体和尾实体(类似于传统关系分类模型中的位置向量),然后使用【CLS】来做分类;
【ENT】:该token表示实体类型,用于entity typing等任务。
试验部分也略过了哈~感觉有些部分还不是很清晰,需要看看源码…
reference
-
ACL 2019将会有哪些值得关注的论文?
-
ACL 2019 | 基于知识增强的语言表示模型,多项NLP任务表现超越BERT
-
ACL 2019 | 清华等提出ERNIE:知识图谱结合BERT才是「有文化」的语言模型
-
官方源码
小结
芝麻街恐成最大赢家:
“ Bert and Ernie live together in an apartment located in the basement of 123 Sesame Street. Despite sleeping in separate beds, they share the same bedroom, which has led to some speculation that they are a representation of gay lovers .”
抛弃模型重名的巧合,这两个工作都是将外部知识融入到基础BERT模型中,不同的是baidu将知识图谱在第一阶段直接编码进了预训练模型,而THU的模型则是选择在第二阶段将知识图谱的信息融入到预训练好的模型中去,可以更好地利用知识图谱中的实体及其内在关系等信息;
以上~
2019.06.03
点击'阅读原文'直达原文链接,欢迎投稿,AI、NLP均可。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 站在BERT肩膀上的NLP新秀们(PART III)
- 站在巨人的肩膀上
- NLP新秀 : BERT的优雅解读
- Unix 风雨五十年:老兵远去,新秀崛起!
- 站在巨人肩膀上的 OR,快到飞起
- NLP 的巨人肩膀(下):从 CoVe 到 BERT
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
敏捷软件开发
Robert C.Martin,、Micah Martin / 邓辉、孙鸣 / 人民邮电出版社 / 2010-12 / 79.00元
要想成为一名优秀的软件开发人员,需要熟练应用编程语言和开发工具,更重要的是能够领悟优美代码背后的原则和前人总结的经验——这正是本书的主题。本书凝聚了世界级软件开发大师Robert C. Martin数十年软件开发和培训经验,Java版曾荣获计算机图书最高荣誉——Jolt大奖,是广受推崇的经典著作,自出版以来一直畅销不衰。 不要被书名误导了,本书不是那种以开发过程为主题的敏捷软件开发类图书。在......一起来看看 《敏捷软件开发》 这本书的介绍吧!