2020.10.26|COLING-2020|中国科学院大学|原文链接|源码链接

TPLinker: Single-stage Joint Extraction of Entities and Relations Through Token Pair Linking

过去的方法:
联合学习可以获得明显的性能增益。 然而,它们通常涉及顺序的相互关联的步骤,并遭受暴露偏差的问题。 在训练时,他们根据地面真值条件进行预测,而在推理时,他们必须从头开始提取。 这种差异导致错误积累。

地面真值:在机器学习中,“ground truth”一词指的是训练集对监督学习技术的分类的准确性。这在统计模型中被用来证明或否定研究假设。“ground truth”这个术语指的是为这个测试收集适当的目标(可证明的)数据的过程。

论文中的方法:
握手标注方法
提出了一个单阶段联合提取模型TPLINKER,它能够发现共享一个或两个实体的重叠关系,同时不受暴露偏差的影响

基础准备

过去阶段一:把实体识别和关系抽取完全分离,容易造成级联错误
过去阶段二:联合学习整合实体和关系信息,使用基于解码器和基于分解的模型解决EPO和SEO,容易产生曝光偏差

基于编码器的:训练时,地面真值令牌被用作为上下文,推理时整个序列整个序列由最终模型自己生成,产生了训练和推理中预测的令牌是从不同的分布中提取的
基于分解的方法:在训练过程中使用黄金实体作为特定的输入来指导训练,在推理过程中输入的中心实体是由经过训练的模型给出的,导致了训练和推理之间的差距

[黄金标准] 是经过注释的数据集(手动 或自动),然后手动更正。

该文章中的:
提出了一种用于实体和重叠关系联合提取的单阶段方法——TPLinker
将联合抽取任务转化为令牌对链接的问题,TPLinker将被用于回答以下问题:
前提条件:给出一个句子、两个位置P1\P2和一个特定关系R

  1. “P1和P2是否分别是同一个实体的开始和结束位置”
  2. “P1和P2是否分别是两个具有R关系的实体的开始位置”
  3. “P1和P2是否分别是两个具有R关系的实体的结束位置”

实施:为每个关系标注了三个令牌链接矩阵,利用这三个令牌链接矩阵回答上述三个问题,然后利用这些矩阵对不同的标注结果进行解码,提取所有实体和重叠关系。
效果:不包含任何相互依赖的提取不走,实现了训练和测试的一致性

方案详解:

握手标记方案:

普通矩阵方案:

通过用链接标记方法进行标记令牌对,实现了一步联合抽取

如上图,给定一个句子,枚举所有可能的令牌对,病使用矩阵标记令牌链接,但是有以下问题:
稀疏矩阵,由于实体尾部不可能出现在实体头部之前,所以下三角区域的标签都是零,这是对内存的巨大浪费。但是,目标实体可能出现在相应的主体实体之前,这意味着直接将下三角区域降下来是不合理的。

三种类型的链接定义:

  1. 实体头到实体尾(EH-to-ET)。 矩阵中的紫色标记是指对应的两个位置分别是一个实体的开始和结束令牌。 例如,“New York CIty”和“de Blasio”是句子中的两个实体,因此,标记对(“new”,“city”)和(“de”,“Blasio”)被赋予紫色标记1。
  2. 主体头到客体头(SH-to-OH)。 红色标签表示两个位置分别是成对的主体实体和对象实体的开始令牌。 例如,“New York CIty”和“de Blasio”之间存在“mayor”关系,因此标记对(“new”和“de”)被分配为红色标记1。
  3. 主语尾到宾语尾(ST-to-OT)。 蓝色标签与红色标签具有类似的逻辑,这意味着两个位置分别是成对的主体实体和对象实体的结束标记。 例如,标记对(“City”、“Blasio”)被分配蓝色标记1。

握手矩阵方案:

下三角区域中的所有标签1映射到上三角区域中标签2,然后删掉下三角区域。为了张量计算方便,将剩下的项压缩成一个序列,即总框架图中的橙色序列,并用一个映射记住原矩阵中的位置,类似于所有令牌中的握手,故称为握手矩阵。

存在的问题:该方案不能处理EPO问题,因为对于同一实体对,不同的关系不能在同一矩阵中标记在一起。
解决方法:我们为每种关系类型做同样的矩阵标记工作。

构造矩阵进行标注:

联合抽取任务被解构为 2 N + 1 2N+1 2N+1个序列标记子任务,其中N表示预定义关系类型的数量,每个子任务建立一个长度为 n 2 + n 2 \frac{n^2+n}{2} 2n2+n​的标记序列,其中 n n n表示输入句子的长度。
存在的问题:标签序列的长度随着句子长度的增加而以平方的形式增加,比较抵消
解决方法:再编码器的顶部使用轻量级标记模型,TPLinker在效率上可以与最先进的模型与之媲美。因为,编码器被所有标记起共享,只需要生成n个令牌表示一次

解码:

  • (“new”,“york”)、(“new”,“city”)和(“de”,“blasio”)在EH-to-ET序列中标记为1
  • “new york”、“new york city”和“de blasio”是三个实体

  • 对于关系“mayor”,(“new”、“de”)在SH-to-OH序列中标记为1
  • “new”开头的主语的mayor是以“de”开头的宾语

  • (“City”、“Blasio”)在ST-to-OT序列中标记为1
  • 主语和宾语分别是以“City”和“Blasio”结尾的实体

  • 由此,可以解码出一个三胞胎:(“New York City”,Major,“Blasio”)

标记2与标记1的含义相反,表示令牌之间的反向链接,因为矩阵中反转了
在关系“born in”的ST-to-OT序列中(“York”、“Blasio”)标记为2,这意味着“York”和“Blasio”分别是成对的宾语和主语的尾部
结合其他两个序列,解码后的应该是(“Blasio”,“born in”,“York”)。


对于每一个关系

  1. 首先从EH-to-ET序列中提取所有的实体跨度,将每个头位置映射到以该位置为起点的相应实体存入字典D
  2. 对于每一个关系,首先从ST-to-OT序列中解码(主题尾位置,宾语尾位置)元组并将其添加到集合E中,然后从SH-to-OH序列中解码(主题头位置,宾语头位置)元组并查找字典D中以头位置为起点的所有可能的实体。
  3. 我们迭代所有候选主宾对,以检查它们的尾位置是否在E中。如果是,则提取一个新的三元组并添加到结果集T中。

令牌对表示:

h i , j = t a n h ( W h ⋅ [ h u ; h j ] + b h ) , j ≥ i (1) h_{i,j} = tanh(W_h\cdot[h_u;h_j] + b_h),j \geq i \tag{1} hi,j​=tanh(Wh​⋅[hu​;hj​]+bh​),j≥i(1)
长度为n的句子 [ w 1 , . . . . , w n ] [w_1,....,w_n] [w1​,....,wn​],通过基本编码器将每个令牌wi映射到一个低维的上下文向量 h i h_i hi​中,燃火可以生成 h i , j h_{i,j} hi,j​来表示令牌对 ( w i , w j ) (w_i, w_j) (wi​,wj​)
W h W_h Wh​是矩阵的参数, b h b_h bh​是要需要训练的偏差向量,在总架构图中称为握手内核


握手标记器

使用统一的架构来标记三种类型的链接,给出令牌对 h i , j h_{i,j} hi,j​
由公式3预测令牌对 ( w i , w j ) (w_i, w_j) (wi​,wj​)

P ( y i , j ) = S o f t m a x ( W o ⋅ h i , j + b o ) (2) P(y_{i,j}) = Softmax(W_o \cdot h_{i,j} + b _o) \tag{2} P(yi,j​)=Softmax(Wo​⋅hi,j​+bo​)(2)

l i n k ( w i , w j ) = a r g max ⁡ l P ( y i , j = l ) (3) link(w_i, w_j) = arg\max_lP(y_{i,j} = l) \tag{3} link(wi​,wj​)=arglmax​P(yi,j​=l)(3)
其中 P ( y i , j = l ) P(y_{i,j} = l) P(yi,j​=l)表示为将 ( w i , w j ) (w_i, w_j) (wi​,wj​)识别为 l l l的概率


握手序列编码器的伪代码:


损失函数

L l i n k = − 1 N ∑ i = 1 , j ≥ i N ∑ ∗ ⊂ { E , H , T } log ⁡ P ( y i , j ∗ = l ∗ ^ ) (4) L_{link} = - \frac {1}{N} \sum_{i=1, j \geq i}^{N} \sum_{* \subset {\lbrace E, H, T \rbrace}}\log P(y_{i,j}^* = \hat{l^*}) \tag{4} Llink​=−N1​i=1,j≥i∑N​∗⊂{E,H,T}∑​logP(yi,j∗​=l∗^)(4)

这里, N N N是输入句子的长度, l ∗ ^ \hat{l^*} l∗^是真标记, E 、 H E、H E、H和 T T T分别表示eh-to-et、sh-to-oh和st-to-ot的标记器。


实验对比

数据集准备

NYT和WebNLG作为数据集

使用Precision、Recall、F1-score作为评判标准

基线对比

(以下为原文)

  • Tplinker在注释最后一个单词的数据集和注释整个跨度的数据集上都表现良好
  • 在NYT和NYT*上的得分几乎相同,这也表明只注释最后一个单词的数据集并不总是比注释整个跨度的数据集容易。 甚至相反,这可能会更难,因为不同的实体可能共享相同的最后一个词,这使得重叠情况的数量增加。
  • WebNLG和WebNLG* 的性能之间存在明显的差距,但发现WebNLG中有127个错误的三元组,包含一个无意义的空实体。 另外,webnlg有216个关系,而webnlg* 只有171个。可能是这些原因造成,为比较,不解决
    1. WebNLG* 的性能已经饱和,因为提取含有171个预定义关系的三元组非常困难,尤其是训练数据很少(5019句)。 这些方法获得了90+F1的分数,可能已经超过了人类水平的表现。 换言之,提振空间太有限。
    1. WebNLG* 中的许多关系具有相同的含义,如LeaderName和Leader,affiliation和affiliations,这给模型带来了混乱。 在许多情况下,我们的模型将提取它们两个,但通常只有其中一个在测试集中被注释。由于 T P L i n k e r b e r t TPLinker_{bert} TPLinkerbert​模型具有较强的提取重叠关系的能力和较好的查全率,因此这些正确注释的缺失严重影响了Tplinkerbert模型的查全率。

知识补充

  • 序列标注:
    • 序列标注是一个比较简单的NLP任务,也可成为最基本的任务。序列标注是给定一个输入序列,使用模型对这个序列的每一个位置标注一个相应的标签,是一个序列到序列的过程。序列标注的涵盖范围非常广,可以解决一系列对字符进行分类的问题,如分词、词性标注、命名实体识别、关系抽取等。
    • 序列标注可分原始标注联合标注,原始标注就是每个元素中都需要被标注的一个标签,联合标注就是所有的分段都被标注为同样的标签,命名实体识别是信息提取问题中的一个子任务,需要将元素进行定位和分类,如人名、地点、时间、组织名、质量等。
  • BIO标注:解决联合标注问题的最简单的方法,就是将其转化为原始标注问题,即使用BIO标注。
    • BIO标注是将每个元素标注为“B-X”、“I-X”或者“O”。其中,“B-X”表示此元素所在的片段属于X类型并且此元素为词片段的起始词“I-X”表示此元素所在的片段属于X类型并且此元素为词片段的起始词之后的词“O”表示该字不属于事先定义的任何词片段类型。
  • 常用的序列标注还有BIOES标注和BMES标注。
    • BIOES标注主要将多元实体X标注为B-X,I-X,E-X的格式,
      B-:实体的开头
      I-:实体的中间
      0-非实体部分;
      E-实体的结尾
      S-单个字符,其本身就是一个实体
    • BMES标注中的
      B-:实体的开头
      M-:实体的中间
      O-:非实体部分
      E-:实体的结尾
      S-单个字符,其本身就是一个实体
      可以看出在很多任务以上各种标注体系的表现差异不大。
  • BERT: BERT:双向Transformer的Encoder

[实体关系抽取]TPLinker: Single-stage Joint Extraction of Entities and Relations Through Token Pair Link相关推荐

  1. 【ACL2020】Relabel the Noise: Joint Extraction of Entities and Relations via Cooperative Multiagents

    文章目录 1.本文问题 2.方法 3.用于 4. 结论 1.本文问题 解决问题: 去噪 shifted label distribution 普遍存在此问题,但大家都不解决,只着重于抛弃噪声实例 远程 ...

  2. 【每周NLP论文推荐】 掌握实体关系抽取必读的文章

    欢迎来到<每周NLP论文推荐>.在这个专栏里,还是本着有三AI一贯的原则,专注于让大家能够系统性完成学习,所以我们推荐的文章也必定是同一主题的. 实体关系抽取作为信息抽取领域的重要研究课题 ...

  3. nlp中的实体关系抽取方法总结

    点击上方,选择星标或置顶,每天给你送干货! 阅读大概需要35分钟 跟随小博主,每天进步一丢丢 来自:知乎 地址:https://zhuanlan.zhihu.com/p/77868938 作者:Jay ...

  4. [论文阅读笔记52]深度学习实体关系抽取研究综述

    来源:软件学报 2019 1.摘要: 围绕有监督和远程监督两个领域,系统总结了近几年来中外学者基于深度学习的实体关系 抽取研究进展,并对未来可能的研究方向进行了探讨和展望. 2.经典的实体关系抽取方法 ...

  5. 深度学习实体关系抽取研究综述笔记

    鄂海红,张文静,肖思琪,程瑞,胡莺夕,周筱松,牛佩晴.深度学习实体关系抽取研究综述.软件学报,2019,30(6): 1793−1818. http://www.jos.org.cn/1000-982 ...

  6. 实体关系抽取学习笔记

    1 关系抽取概述 1.1 简介 信息抽取旨在从大规模非结构或半结构的自然语言文本中抽取结构化信息.关系抽取是其中的重要子任务之一,主要目的是从文本中识别实体并抽取实体之间的语义关系. 关系抽取对于很多 ...

  7. 知识图谱从哪儿来?实体关系抽取的现状和未来

    12月17日晚,2019年清华特奖获得者之一,清华大学自然语言处理实验室大四本科生高天宇,在智源论坛Live第1期,以<实体关系抽取的现状和未来>为主题,与150位观众进行了在线交流.本文 ...

  8. 技术动态 | 知识图谱从哪里来:实体关系抽取的现状与未来

    本文作者为:韩旭.高天宇.刘知远.转载自刘知远老师的知乎专栏,文章链接:https://zhuanlan.zhihu.com/p/91762831 最近几年深度学习引发的人工智能浪潮席卷全球,在互联网 ...

  9. 实体关系抽取几篇论文

    1.<A Unified MRC Framework for Named Entity Recognition> paper:https://arxiv.org/pdf/1910.1147 ...

最新文章

  1. 服务器虚拟化win游戏,Win虚拟化之Windows Virtual PC 功能概述
  2. Mysql学习总结(71)——MySQL 重复记录查询与删除总结
  3. Linux下PhpMyAdmin程序目录的安全管理
  4. 【JAVA 数据结构】 JAVA实现动态数组
  5. Nessus插件离线下载
  6. html-5表白神器源码,html5开发表白神器实现代码
  7. YOCTO开机画面修改
  8. 2TB虚拟本地磁盘实验
  9. Couch的MapReduce查询
  10. java中交换机的作用_交换机链路聚合在网络中的作用
  11. ubuntu18本地镜像源_Ubuntu 18.04 搭建私有软件镜像源(支持 Ubuntu 和 CentOS)
  12. 国企招聘:中国空空导弹2023校园招聘正式启动
  13. Java面试题及答案2019版(下),mysql事务隔离级别原理
  14. HTML、CSS实现手风琴效果
  15. excel和python建模_如何用Python提高办公(Excel)效率?
  16. 技嘉服务器主板型号,服务器配件 全面认识技嘉服务器主板
  17. 静态链接库(Lib)和动态链接库(DLL)
  18. ffmpeg处理视频与声音
  19. Java 8 Update 251 (8u251)
  20. 求一个数的每一位分别是多少

热门文章

  1. 从上海医保聊一聊大公司的一种病
  2. 有没有专门针对优盘的杀毒软件?
  3. 逆向QBasic7.1笔记
  4. 计算机basic基本指令,DOS的Interlnk、Intersvr、Qbasic命令使用说明 -电脑资料
  5. vba传值调用_vba中OnAction属性指定宏名时如何传递参数?
  6. 简述改变计算机桌面背景的方法,桌面背景不能更换怎么办 桌面背景不能更换解决方法【详细介绍】...
  7. 【IPA-ACV】Marr-Hildreth边缘检测器
  8. 2015070802 - 黑鹰坠落
  9. 敬刚(/即将)踏入社会#127568;️程序猿!
  10. PO/DO/DTO/VO/BO/POJO/DAO解释