Abstract
实体识别和关系抽取比较依赖NLP工具(词性标记POS、依赖关系等),本文提出一种不需要人工或工具提取特征并且能同时进行实体和关系等候区的模型,即使用CRF抽取实体,将关系抽取看做多头选择问题,为每一个实体识别潜在的多种关系(实体重叠)。
Model
本文将联合关系抽取建模为一项多头选择问题(一个特定的实体可能涉及到与其他实体的多种关系),模型能够同时识别实体(类型和边界)以及它们之间的关系。
- Embedding Layer
- 将word进行词嵌入
- Bi-LSTM Encoder Layer
- 得到双向的信息: h i = [ h i → ; h i ← ] h_i=[\overset{\rightarrow}{h_i};\overset{\leftarrow}{h_i}] hi=[hi→;hi←]
- Named Entity Recognition
- 计算每个实体 w i w_i wi对应的所有标签得分: s e ( h i ) = v e f ( U e h i + b e ) s^e(h_i)=v ^ef(U^eh_i+b^e) se(hi)=vef(Uehi+be)
- f f f表示激活函数, V e ∈ R p × l , U e ∈ R l × 2 d , p V^e\in R^{p\times l},U^e\in R^{l\times 2d},p Ve∈Rp×l,Ue∈Rl×2d,p是识别的标签个数
- 给定的token w i w_i wi的候选tags的概率: P r ( t a g ∣ w i ) = softmax ( s ( h i ) ) ∈ R p Pr(tag|w_i) = \text{softmax}(s(h_i))\in R^p Pr(tag∣wi)=softmax(s(hi))∈Rp
- 采用共享参数的方式进行关系抽取,即使用实体标签作为输入,输入到关系提取层学习标签嵌入,因此关系抽取层的输入由两个:
- LSTM的输出 h i h_i hi,学习到的标签嵌入表示 g i g_i gi
- z i = [ h i ; g i ] z_i=[h_i;g_i] zi=[hi;gi]
- Relation Extraction as Multi-head Selection
- 采用多头选择时,为了避免造成信息冗余,只判断每个实体的最后一个token与其他实体的最后一个token的关系,而每体的最后一个token被称为head
- 对于每个head,需要预测二元组
(
y
i
∧
,
c
i
∧
)
(\overset{\wedge}{y_i},\overset{\wedge}{c_i})
(yi∧,ci∧),其中前者代表头实体(subject),后者是关系
- 给定一个序列 w w w和一个关系标签 R \mathcal{R} R作为输入,目标是为每个token w i w_i wi标识最有可能的head和最有可能的对应关系标签 r i ∧ ∈ R \overset{\wedge}{r_i} \in \mathcal{R} ri∧∈R
- 给定标签 r k r_k rk的情况下,计算 w i w_i wi和 w j w_j wj之间的分数为: s r = V r f ( U r z j + W r z i + b r ) s^r=V^rf(U^rz_j+W^rz_i+b^r) sr=Vrf(Urzj+Wrzi+br)
- 将分数映射成概率: P r ( h e a d = w j , l a b e l = r k ∣ w i ) = σ ( s r ( z j , z i , r k ) ) Pr(head=w_j,label=r_k|w_i)=\sigma(s^r(z_j,z_i,r_k)) Pr(head=wj,label=rk∣wi)=σ(sr(zj,zi,rk))
Result
启示
- 将其转换为多头选择的方法在这个领域具有开创性,ACE04的分数竟然没想到这么高,还在没用BERT的情况了,牛皮。
- 选择头的算法可以将其转换为选择尾的。