命名实体识别: BiLSTM 之上的 CRF 层 - 2

回顾

上一篇文章 中, 我们了解到 CRF 能够从训练数据中学习到有关 Labels 序列的约束,进而可以确保最终的实体标注序列是合理有效的。

这些约束可以是:

  • 句子中首个单词的 Label 应该是 “B-“ or “O”, 而不会是 “I-“

  • “B-label1 I-label2 I-label3 I-…”,在这个模式中, label1, label2, label3 … 应该是同一实体的 Label。譬如,“B-Person I-Person” 是合理有效的,但是 “B-Person I-Organization” 便是无效的。

  • “O I-label” 是无效的。命名实体的第一个起始标注应该是 “B-“ 开头的,而不是 “I-“。换一句话说,合理有效的模式应该是 “O B-label”

  • ...

在读完这篇文章后,你将会知道为什么 CRF 能够学习到这些约束。

2. CRF Layer

在 CRF 层的 Loss Function 中,我们有两种 Score ,Emission Score 和 Transition Score 它们是 CRF 层的关键。

2.1 Emission Score

第一个便是 Emission Score 。这里的 Emission Scores 来自于 BiLSTM 层,如下图所示,w_0 被标记为 B-Person 的 score 是 1.5

为了方便理解,在这里给每个 label 一个索引标签:

我们使用 x_{i,y_j} 表示 Emission Score,i 是 word 的 index, y_j 是 label 的 index。譬如,依据上面的图可以得到,x_{i=1,y_j=2} = x_{w1, B-Organization} = 0.1, 意思就是 w_1 被标注为 B-Organization 的 score 为 0.1。

2.2 Transition Score

对于 Transition Score ,我们使用 t_{y_jy_j} 表示。譬如,t_{B-Persion, I-Person} = 0.9,意思就是标签 B-Persion 转移到 I-Person 的 score 为 0.9。这样的话,我们便拥有了一个 转移矩阵,其中存储着所有标签之间的 Transition Score。

为了使得转移分数矩阵更加具有鲁棒性,我们得添加一些标签,START 和 END。START 表示句子的起始,并不是句子的第一个 word;END 表示句子的结束。

这里就是一个 transition matrix score 的例子,其中包含了我们额外添加的START 和 END 标签。

如上表所示,我们能够发现这个状态转移举证已经学习到了某些约束了。

  • 句子中的第一个单词的标记应该是以“B-“ 或者 “O”开头, 并不会是 “I-”形式的标记。(可以从表中发现, “START” 到 “I-Person or I-Organization” 的转移值非常的小。)

  • 在“B-label1 I-label2 I-label3 I-…”这样形式的标注序列中, label1, label2, label3 … 应该是同种实体的标签。比如,“B-Person I-Person” 是合理有效的标注序列,而 “B-Person I-Organization” 则不是。(譬如, the score from “B-Organization” to “I-Person” is only 0.0003 which is much lower than the others.)

  • “O I-label” is invalid. The first label of one named entity should start with “B-“ not “I-“, in other words, the valid pattern should be “O B-label” (表中 t_{O, I-Person} 的值非常的小。)

好了,这时候你脑子里该满是黑人问号了,这个矩阵从哪里来的??

确切的说,这个矩阵是 BiLSTM-CRF 模型的一个参数。在你训练模型之前,你可以随机地初始化矩阵中所有的 transition score。在之后的训练过程中,这些随机初始化的 score 将会被自动更新。换句话说,CRF 层可以自己学习到这些约束。我们并不需要手动创建这样一个矩阵。这些分数值会随着训练的迭代次数的增加,变得越来越 “合理”。

2.3 CRF loss function

CRF 的损失函数由 真实转移路径值 和 所有可能转移路径值两部分组成。真实路径表示在所有可能转移路径中具有最高 score 的路径。

假如我们的数据集中有这样一些标记:

image.png

我们也有一个由 5 个单词组成的句子,那么标签的可能转移路径有:

1.START B-Person B-Person B-Person B-Person B-Person END

2.START B-Person I-Person B-Person B-Person B-Person END

10.START B-Person I-Person O B-Organization O END

N.O O O O O O O

假定每一个可能的路径有一个分数值 P_i, 那么对于所有 N 条可能的路径的总分数值为 P_{total} = P_1 + P_2 + P_3 + ... + P_N = e^{S_1} + e^{S_2} + e^{S_3} + ... + e^{S_N},e 是数学常量 e。(在 2.4 节,我们会讨论如何计算 S_i,你也可以将它直接作为该路径的分数值。)

假如这里的第十条路径是真实的路径,换句话说,第十条路径是训练集提供的“黄金准则”。那么, P_{10} 就应该在所有的路径分数值之和中占据最大的比例。

下面给出方程便是我们一直讨论的 Loss Function,在训练阶段,BiLSTM-CRF 模型的参数值将会一直不停的被更新,来提高真实路径的分数值所占的比重。

Loss Function = P_{RealPath} / P_{1}+P_{2}+P_{3}+P_{4}+...+P_{N}

现在,问题来了:

  1. 如何定义一条路径的分数值?
  2. 如何计算所有路径的总分数值?
  3. 当我们计算所有分数值的时候,我们需要列出所有可能的路径吗?(提前透露一下答案:不需要!)

Real path score

今天就到这里吧~

参考文献
[1] Lample, G., Ballesteros, M., Subramanian, S., Kawakami, K. and Dyer, C., 2016. Neural architectures for named entity recognition. arXiv preprint arXiv:1603.01360.
[2] https://createmomo.github.io/2017/09/23/CRF_Layer_on_the_Top_of_BiLSTM_2/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容