昇思25天学习打卡营第21天|LSTM+CRF序列标注

1. 学习内容复盘

概述

序列标注指给定输入序列,给序列中每个Token进行标注标签的过程。序列标注问题通常用于从文本中进行信息抽取,包括分词(Word Segmentation)、词性标注(Position Tagging)、命名实体识别(Named Entity Recognition, NER)等。以命名实体识别为例:

输入序列
输出标注 B I I I O O O O O B I

如上表所示,清华大学 和 北京是地名,需要将其识别,我们对每个输入的单词预测其标签,最后根据标签来识别实体。

这里使用了一种常见的命名实体识别的标注方法------"BIOE"标注,将一个实体(Entity)的开头标注为B,其他部分标注为I,非实体标注为O。

条件随机场(Conditional Random Field, CRF)

从上文的举例可以看到,对序列进行标注,实际上是对序列中每个Token进行标签预测,可以直接视作简单的多分类问题。但是序列标注不仅仅需要对单个Token进行分类预测,同时相邻Token直接有关联关系。以清华大学一词为例:

输入序列
输出标注 B I I I
输出标注 O I I I ×

如上表所示,正确的实体中包含的4个Token有依赖关系,I前必须是B或I,而错误输出结果将清字标注为O,违背了这一依赖。将命名实体识别视为多分类问题,则每个词的预测概率都是独立的,易产生类似的问题,因此需要引入一种能够学习到此种关联关系的算法来保证预测结果的正确性。而条件随机场是适合此类场景的一种概率图模型。下面对条件随机场的定义和参数化形式进行简析。

考虑到序列标注问题的线性序列特点,本节所述的条件随机场特指线性链条件随机场(Linear Chain CRF)

设x={x0,...,xn}𝑥为输入序列,y={y0,...,yn},y∈Y为输出的标注序列,其中n为序列的最大长度,Y表示x对应的所有可能的输出序列集合。则输出序列y的概率为:

设xi, yi为序列的第i个Token和对应的标签,则Score需要能够在计算xi和yi的映射的同时,捕获相邻标签yi−1和yi之间的关系,因此我们定义两个概率函数:

  1. 发射概率函数ψEMIT:表示xi→yi的概率。
  2. 转移概率函数ψTRANS:表示yi−1→yi的概率。

则可以得到Score的计算公式:

设标签集合为T,构造大小为|T|x|T|的矩阵P,用于存储标签间的转移概率;由编码层(可以为Dense、LSTM等)输出的隐状态h可以直接视作发射概率,此时Score的计算公式可以转化为:

完整的CRF完整推导可参考Log-Linear Models, MEMMs, and CRFs

接下来我们根据上述公式,使用MindSpore来实现CRF的参数化形式。首先实现CRF层的前向训练部分,将CRF和损失函数做合并,选择分类问题常用的负对数似然函数(Negative Log Likelihood, NLL),则有:

【】

由公式(1)可得,

根据公式(5),我们称被减数为Normalizer,减数为Score,分别实现后相减得到最终Loss。

Score计算

首先根据公式(3)计算正确标签序列所对应的得分,这里需要注意,除了转移概率矩阵P外,还需要维护两个大小为|T|的向量,分别作为序列开始和结束时的转移概率。同时我们引入了一个掩码矩阵mask,将多个序列打包为一个Batch时填充的值忽略,使得Score计算仅包含有效的Token。

Normalizer计算

根据公式(5),Normalizer是x对应的所有可能的输出序列的Score的对数指数和(Log-Sum-Exp)。此时如果按穷举法进行计算,则需要将每个可能的输出序列Score都计算一遍,共有|T|n个结果。这里我们采用动态规划算法,通过复用计算结果来提高效率。

假设需要计算从第0至第i个Token所有可能的输出序列得分Scorei,则可以先计算出从第0至第i−1个Token所有可能的输出序列得分Scorei−1。因此,Normalizer可以改写为以下形式:

其中hi为第i个Token的发射概率,P是转移矩阵。由于发射概率矩阵h和转移概率矩阵P独立于y的序列路径计算,可以将其提出,可得:

Viterbi算法

在完成前向训练部分后,需要实现解码部分。这里我们选择适合求解序列最优路径的Viterbi算法。与计算Normalizer类似,使用动态规划求解所有可能的预测序列得分。不同的是在解码时同时需要将第i个Token对应的score取值最大的标签保存,供后续使用Viterbi算法求解最优预测序列使用。

取得最大概率得分Score,以及每个Token对应的标签历史History后,根据Viterbi算法可以得到公式:

从第0个至第i个Token对应概率最大的序列,只需要考虑从第0个至第i−1个Token对应概率最大的序列,以及从第i𝑖个至第i−1个概率最大的标签即可。因此我们逆序求解每一个概率最大的标签,构成最佳的预测序列。

由于静态图语法限制,我们将Viterbi算法求解最佳预测序列的部分作为后处理函数,不纳入后续CRF层的实现。

CRF层

完成上述前向训练和解码部分的代码后,将其组装完整的CRF层。考虑到输入序列可能存在Padding的情况,CRF的输入需要考虑输入序列的真实长度,因此除发射矩阵和标签外,加入seq_length参数传入序列Padding前的长度,并实现生成mask矩阵的sequence_mask方法。

BiLSTM+CRF模型

在实现CRF后,我们设计一个双向LSTM+CRF的模型来进行命名实体识别任务的训练。模型结构如下:

复制代码
nn.Embedding -> nn.LSTM -> nn.Dense -> CRF

其中LSTM提取序列特征,经过Dense层变换获得发射概率矩阵,最后送入CRF层。

2.平台实验结果

相关推荐
图王大胜1 分钟前
模型 双螺旋(通俗解读)
人工智能·管理·系统科学·认知科学·生命科学·战略规划·通识科学
kkflash36 分钟前
提升专业素养的实用指南
学习·职场和发展
dwjf32120 分钟前
机器学习(四)-回归模型评估指标
人工智能·机器学习·线性回归
吕小明么24 分钟前
OpenAI o3 “震撼” 发布后回归技术本身的审视与进一步思考
人工智能·深度学习·算法·aigc·agi
1 9 J41 分钟前
数据结构 C/C++(实验五:图)
c语言·数据结构·c++·学习·算法
算力魔方AIPC1 小时前
Meta重磅发布Llama 3.3 70B:开源AI模型的新里程碑
人工智能·llama
CSBLOG1 小时前
深度学习试题及答案解析(一)
人工智能·深度学习
四口鲸鱼爱吃盐1 小时前
Pytorch | 利用VMI-FGSM针对CIFAR10上的ResNet分类器进行对抗攻击
人工智能·pytorch·python
四口鲸鱼爱吃盐1 小时前
Pytorch | 利用PI-FGSM针对CIFAR10上的ResNet分类器进行对抗攻击
人工智能·pytorch·python
边缘计算社区2 小时前
吉快科技荣膺“金边奖·最佳大模型一体机”,引领AI边缘新时代
人工智能·科技