2. 北京市科学技术情报研究所, 北京 100048
2. Beijing Institute of Science and Technology Information, Beijing 100048, China
自然语言处理(Nature Language Processing)是近年来快速发展的一门涵盖了数学、语言学和计算机科学的交叉学科. 其旨在让计算机能够正确的理解人类的语言, 并且实现人与机器之间通过自然语言进行交互, 其中包括信息抽取、机器翻译、信息检索、问答系统等方面[1].
命名实体识别是自然语言处理的一项关键任务, 在1995年的MUC会议上被第一次引入, 目的是识别文本中的特定类型的事物名称和有意义的数量短语, 包括命名性实体、时间、数字等三大类, 又可细分为七个小类: 人名、地名、机构名、时间、日期、货币以及百分比等[2]. 作为自然语言处理中的一项基础任务, 命名实体识别对于机器翻译、信息的检索与抽取等工作有重要意义. 随着时代的发展, 命名实体识别的目标早已超出了上述几类的范围, 特定领域的命名实体识别需求非常广泛, 如电子病历、生物医学等领域, 本文的子实验既是在会议名称识别这一特定领域的命名实体上展开的. 除了需要识别的实体在不断增加外, 命名实体识别方法也在不断进步和完善[3–5].
传统的命名实体识别多采用基于规则和统计机器学习的方法. 最初, 命名实体识别采用基于手工制定词典和规则的方法. 这些方法大多以语言学专家建立的规则知识库和词典为基础, 采用模式匹配或者字符串匹配的方法识别命名实体[6,7]. 对于规律性强的文本, 基于规则的方法准确而且高效. 但对于规律性不强的文本, 规则的编写变得困难, 识别效果也相当不理想, 所以人们开始将目光投向机器学习的方法.
在命名实体识别领域常用的机器学习方法有隐马尔可夫模型(Hidden Markov Model, HMM)、条件随机场模型(Conditional Random Fields, CRF)、最大熵模型(Maximum Entropy)、支持向量机模型(Support Vector Machine, SVM)等[8–10]. 其中最典型的也是应用比较成功的是隐马尔可夫模型和条件随机场模型. 基于机器学习的方法在迁移性、识别效果等方面的表现优于基于规则的方法, 但使用统计机器学习方法的命名实体识别模型也存在一些局限性. 一方面, 为了使推理易于处理, 它需要明确的依赖性假设; 另一方面, 以统计模型为基础的机器学习方法对特征选取的要求比较高, 需要选择对命名实体识别任务有影响的各种特征, 即特征工程(feature engineering), 它对识别结果有重要影响, 但是该过程费时费力[11–14]; 最后, 它们通常需要大量的与任务相关的特定知识, 如设计HMM的状态模型, 或选择CRF的输入特征.
随着深度学习研究的不断深入, 人们开始引入深度神经网络来处理自然语言. 2011年Collobert提出一种基于窗口的深层神经网络模型, 该模型可以自动学习输入句子中的抽象特征, 在训练中使用反向传播算法来训练参数. 其效果和性能超过了之前的传统算法. 该模型的主要局限性是使用固定长度的上下文, 不能充分的利用语境信息[15–18]. Mikolov于2010年提出一种基于循环神经网络(Recurrent Neural Networks, RNNs)的语言模型, 它不使用固定大小的上下文信息, 通过重复链接, 信息可以在这些网络内循环, 这种信息循环的方式非常适用于处理序列数据[19–24].
本文利用循环神经网络在处理序列数据方面的优势, 建立了基于循环神经网络的命名实体识别模型. 循环神经网络包含多种不同的变体, 经过分析对比, 本文最终选用了由RNN改进而来、结构相对简单的GRU. 本文结构安排如下: 第2节介绍语料库的构建; 第3节阐述基于GRU的命名实体识别模型; 第4节是实验和分析; 最后做全文总结.
2 基于GRU的命名实体识别模型以字作为输入单位容易产生歧义, 需要根据具体的语境信息判断每个字的标签, 循环神经网络能很好的计算和保持语境信息. RNN是比较简单的循环神经网络, 不含“门”结构, 训练时会出现梯度消失或梯度爆炸的问题. LSTM与GRU是在RNN的基础上改进而来的循环神经网络, 本文分析了RNN、LSTM和GRU三种循环神经网络之间的关系, 在此基础上, 提出了一个基于GRU的命名实体识别模型. 该模型以字向量作为输入, 经过双向GRU层计算, 提取句子特征, 经softmax层计算得到一个相应的输出序列.
2.1 循环神经网络循环神经网络是深度学习中常用的一类神经网络, 包括RNN和RNN的变体LSTM、GRU等, 它利用序列信息并通过中间层保持这些信息, 这使它在处理序列数据时有独特优势.
RNN将一个向量序列
${{{h}}_t} = f\left( {{\bf{U}}{{{s}}_t} + {\bf{W}}{{{h}}_{t - 1}}} \right)$ | (1) |
${{{o}}_t} = {\bf{V}}{{{h}}_t}$ | (2) |
U、V、W是权值矩阵,
理论上RNN可以学习长期依赖, 但实际上它不能实现这个目标, 因为根据求导的链式法则, 公式(1)使得损失函数的梯度成为连续乘积的形式, 这样做会导致梯度消失或者梯度爆炸的问题.
为了解决梯度消失(或者梯度爆炸)的问题, Hochreiter和Schmidhuber[25]提出了一种RNN的改进型网络: LSTM. 在自然语言处理中常用的LSTM可以用如下公式来描述:
$\left\{\begin{array}{l}{{{f}}_t} = \sigma \left( {{{\bf{W}}_f} \cdot \left[ {{{{h}}_{t - 1}},{{{s}}_t}} \right] + {{{b}}_f}} \right)\\{{{i}}_t} = \sigma \left( {{{\bf{W}}_i} \cdot \left[ {{{{h}}_{t - 1}},{{{s}}_t}} \right] + {{{b}}_i}} \right)\\{{{\tilde{ C}}}_t} = \tanh\left( {{{\bf{W}}_c} \cdot \left[ {{{{h}}_{t - 1}},{{{s}}_t}} \right] + {{{b}}_c}} \right)\\{{{C}}_t} = {{{f}}_t} \odot {{{C}}_{t - 1}} + {{{i}}_t} \odot {{{\tilde{ C}}}_t}\\{{{o}}_t} = \sigma \left( {{{\bf{W}}_o} \cdot \left[ {{{{h}}_{t - 1}},{{{s}}_t}} \right] + {{{b}}_o}} \right)\\{{{h}}_t} = {{{o}}_t} \odot \tanh\left( {{{{C}}_t}} \right)\end{array}\right.$ | (3) |
其中,
本文使用的GRU是RNN的另一种改进模型, 它与LSTM非常类似, 也是通过门来保持序列信息, 同时克服RNN中的梯度消失问题. 它的公式如下:
$\left\{\begin{array}{l}{{{r}}_t} = \sigma \left( {{{\bf{W}}_r} \cdot \left[ {{{{h}}_{t - 1}},{{{s}}_t}} \right]} \right)\\{{{z}}_t} = \sigma \left( {{{\bf{W}}_z} \cdot \left[ {{{{h}}_{t - 1}},{{{s}}_t}} \right]} \right)\\{{{\tilde{ h}}}_t} = \tanh \left( {{{\bf{W}}_{\tilde h}} \cdot \left[ {{{r}} \odot {{{h}}_{t - 1}},{{{s}}_t}} \right]} \right)\\{{{h}}_t} = \left( {1 - {{{z}}_t}} \right) \odot {{{h}}_{t - 1}} + {{{z}}_t} \odot {{{\tilde{ h}}}_t}\end{array}\right.$ | (4) |
其中,
近年来, 很多学者使用前馈神经网络进行命名实体识别, 得到了不错的效果, 这种方法一般使用输入窗口, 即利用固定长度的输入来学习待识别词的上下文信息, 它的结构可以用图2描述.
因为窗口大小有限(如上图的窗口大小是3), 所以该方法学习上下文信息的能力不足. 另一方面, 该神经网络的隐藏层状态之间没有联系, 不能够学习到长期依赖, 对于序列标注任务来说, 这意味着丢失了序列信息.
循环神经网络的输入则不受窗口大小的限制, 并且网络的隐藏层之间是有联系的, 即携带了序列信息, 如图3所示.
图2和图3中, xt表示t时刻对应的字或者词. 以字作为输入单位, 命名实体的长度一般会超过三个字, 使用基于窗口的方法无法将整个名称作为一个整体考虑, 容易丢失信息, 致使边界判定准确率低, 而且基于字的判别对上下文环境的依赖程度更高. 循环神经网络学习上下文信息与窗口大小无关, 实现了学习长期依赖的目的, 适用于命名实体较长的情况. 本文分别使用循环神经网络的变体LSTM和GRU作为模型的基本算法, 并且对比说明了GRU的优势.
为了充分利用每个字的上下文信息, 这里使用了一个双向GRU结构, 即考虑了句子的正向和反向两个方向上的序列信息. 另外, 用于会议等新实体识别的用料库一般较小, 所以模型的结构不宜过复杂, 否则容易出现过拟合的现象. 本文设计的命名实体识别模型如图4所示.
图4中, 模型的第一层和第二层分别对应输入层和Embedding层. 由于神经网络不能直接处理自然语言符号, 所以, 应该将输入的字或者词转换成对应的向量, 即Embedding层的工作, 其中, 向量
这里可以把命名实体识别当作一个序列标注过程, 对于一个输入序列:
${{X}} = \left( {{x_1},{x_2}, \cdots ,{x_n}} \right)$ | (5) |
经过模型计算, 给每个输入
${{y}} = \left( {{y_1},{y_2}, \cdots ,{y_n}} \right)$ | (6) |
对于输入
${{{y}}_t} = softmax \left( {{{{o}}_t}} \right)$ | (7) |
${\tilde y_i} = \frac{{{e^{{{\tilde y}_i}}}}}{{\sum\nolimits_1^n {{e^{{{\tilde y}_i}}}} }}$ | (8) |
其中,
训练时, 使用交叉熵作为代价函数:
$Loss = - \sum\limits_{i = 1}^n {{y_i}} \log {\tilde y_i}$ | (9) |
其中,
得到代价函数后, 通过训练集训练模型, 对于训练集的使用, 一般有批量梯度下降、随机梯度下降和mini-batch gradient(小批量梯度下降)三种方法, 本文使用第三种方法, 因为批量梯度下降方法每次计算损失函数都要遍历整个训练集, 并通过计算函数对所有参数的梯度来更新参数, 这种方法每更新一次参数就要遍历一次训练集, 导致计算开销很大, 计算速度较慢; 随机梯度下降法每次计算损失函数仅使用一条数据, 并通过梯度下降来更新参数. 与第一种方法相比, 虽然该方法的计算速度比较快, 但是收敛性能较差; 而第三种方法则结合了二者的优点, 它把训练数据分成多个批次, 计算损失函数时只使用其中的一批. 这样, 梯度的方向由这一小批次中的数据共同决定, 降低了方向选择的随机性, 提高了收敛性能; 同时, 与整个训练集相比, 每个批次数据量要小很多, 这降低了计算量, 节省了计算开销.
过拟合是使用人工神经网络时经常遇到的问题, 尤其是语料规模较小时, 更容易产生过拟合现象, 为了解决这个问题, 本文采用了DropOut方法. DropOut是Srivastava[26]提出的用来解决前馈神经网络过拟合问题的方法, 它通过在训练过程中随机的让一些神经元暂时停止工作来增加网络的稀疏性. 与权重衰减、过滤器范数约束等其它防止过拟合的方法相比, DropOut方法更有效, 而且计算方便, 只需要在训练过程中产生相应的随机数来控制神经元的开闭即可. 在循环神经网络中, 将DropOut应用到非循环层, 这样做即能有效的避免过拟合的出现, 又能保证神经元之间不失去“联系”, 保存了序列信息.
本文提出的模型需要在监督训练数据上进行训练. 对于特定领域的命名实体识别来说, 往往没有可用的标注语料, 自己构建的语料库规模又比较小, 为了提高模型的效果, 一方面, 应当尽可能降低模型的复杂程度, 所以, 本文设计的模型只使用了一层双向GRU结构; 另一方面, 将已有的相关标注语料融合到自建语料库中, 可以丰富预料的语境语义特征, 提高识别效果, 第3节通过实验说明了该方法的可行性.
3 实验与分析本文分别在人名这一传统命名实体和会议名称这个特定领域实体上进行了实验. 人名识别实验使用的是人民日报语料库. 会议名称识别使用的是自建语料库. 由于本文的成果最终要运用到情报所的工作实践中, 所以两类实验使用的都是字向量, 第3.2节会进一步分析使用字向量的优势.
3.1 语料库构建语料库是进行自然语言处理必须的数据集, 它承载着重要的语言知识. 基于神经网络的命名实体识别需要带标注的预料库作为训练数据. 本文除了在传统命名实体领域测试模型外, 还使用会议名称这一特定领域实体对模型进行了测试. 由于目前没有会议名称识别的语料库, 本文通过搜集文本、筛选、分词和标注等步骤构建了一个针对会议名称识别的语料库.
文本搜集是构建语料库的第一步. 本文搜集的文本来自中国学术会议在线网. 这里搜集了会议预告、会议新闻、会议评述、会议回顾的相关材料, 一共得到了31.2 M的初始文本.
第二步需要人工筛选搜集的文本, 删除大量与会议名称无关的段落, 并使用结巴分词对文本句子进行切分, 形成了初步标识的语料库.
第三步, 标注已经处理过的文本, 即人工标注会议名称. 会议名称有两种, 一种是简单会议名称, 如“中国医学会年会”、“香山论坛”、“十八届四中全会”等, 这类名称不存在嵌套, 属于简单的会议名称; 第二种是结构复杂的会议名称, 包括嵌套格式、并列结构等, 如“香山科学会议第473次学术讨论会”、“第四届中国古籍数字化国际学术研讨会暨第六届文学与资讯技术国际研讨会”. 本文采取的策略是最大化边界, 即将最完整的会议名称作为一个标注单位, 给予会议标签, 完成标注. 这样做的优势是可以根据后续实验的具体策略灵活的改变会议名称的标注方式, 既可以采用并列结构分别标注的方法, 也可以采用整体标注的方法.
完成上述步骤后, 得到了一个针对会议名称识别的专用语料库, 为实验提供了可用的数据集.
3.2 字向量语料库中的数据并不能直接输入到本文的模型中, 因为神经网络只能计算数字, 所以应先将词或者字转换成数字形式, 即转换成向量. 传统的方法是先将文本分词, 以词向量作为输入单位. 以词作为输入单位需要首先进行分词, 本文没有采用先分词再识别的方法, 而是直接使用字向量作为模型的输入, 采用字向量有如下两点优势:
1) 以字作为输入单位可以避免不同分词系统及分词错误对识别效果的影响, 节省了分词时间, 提高了模型的识别速度;
2) 新领域的自建语料库相对较小, 如果以词作为输入单位, 那么测试时会遇到很多未登录词, 降低识别效果. 而常用汉字不超过3000个, 相对于词, 数据集覆盖的字的种类更加全面, 采用字向量可以避免因为未登录词过多而影响识别效果的情况.
会议名称识别中, 为了进一步提高模型的泛化能力, 训练字向量时采用了两种数据集, 一种是基于自建语料库的数据集, 记为DataSet1; 另一种则通过加入人民日报语料库扩展了原有数据集, 这种扩展并没有增加带标注的会议语料的规模, 只是增加了与会议无关的文本, 达到丰富数据集特征的目的, 该数据集记为DataSet2. 本文使用的字向量随循环神经网络训练过程产生.
3.3 标注策略与评价指标命名实体识别中常用的标注策略有BIO、BIEO、BIESO, O表示不是实体, S表示单个实体, B表示实体其实边界, I表示实体的中间部分, E表示实体的结束边界. 由于本文采用的是输入形式是字向量, 所以必须同时找出起始和结束边界, 所以采用BIEO形式的标注策略. 命名实体识别的结果是否正确有两个标准: ① 实体的边界正确, 类型正确; ② 类型正确, 边界只覆盖了实体的一部分. 只要满足上述两个条件中的一个, 就认为识别结果是正确的.
本文使用精确率、召回率和F值来评价模型的识别效果. 命名实体识别可以看做分类问题, 以人名识别为例, 正类(Positive)表示该词的预测结果是人名, 负类(Negative)表示该词的预测结果不是人名. 人名被正确识别的个数为TP, 即正类中真正的人名个数是TP; 正类中非人名的个数为FP; 负类中非人名的个数为TN; 负类中被错误识别的个数为FN, 即被预测为负类的人名的个数是FN. 则精确率P、召回率R、F值的计算公式如下:
${P} = \frac{{TP}}{{TP + FP}}$ | (10) |
${R} = \frac{{TP}}{{TP + FN}}$ | (11) |
${F} = \frac{{P*R*2}}{{P + R}}$ | (12) |
通过上述评价指标, 文章对比了LSTM、GRU和RNN的识别效果.表1是人名的识别结果, 可以看出, 三种网络在召回率方面相差较少, 但是GRU的识别结果的准确率更高, 得到了最高的F值.
表2和表3分别是在DataSet1和DataSet2上对会议名称进行识别的结果, 观察两个表可知, 在两个数据集上, GRU的都得到了最高的F值. 由表2实验结果可知, 在DataSet2数据集上训练的模型, 效果要好于DataSet1上训练的模型. 虽然DataSet2数据集只是增加了与会议无关的文本, 但它丰富了文本特征, 提高了模型的泛化能力.
表4是GRU和LSTM的训练时间, 根据实验结果可知, GRU与LSTM的效果相差并不显著, 但是由于GRU结构相对简单, 参数较少, 所以它的训练时间比LSTM减少约15%, 这是GRU的优势所在.
4 结束语
本文提出了一个基于GRU的会议名称识别模型, 并且在传统命名实体和特定领域实体两类实体上进行了实验, 并且根据识别会议名称的需要搜集了会议文本, 通过机器分词和人工标注构建了语料库. 本文使用的方法的最大的优势是不依赖外部知识, 省去了人工设计特征的繁琐工作, 是一种端到端的会议名称识别方法. 识别特定领域命名实体是命名实体识别的一个发展方向, 但经常面临没有监督训练数据的困境, 自建的数据库又比较小, 这就在一定程度上限制了神经网络模型的泛化能力, 如何利用自建的小语料集训练一个具有足够泛化能力的神经网络模型是一个值得探索的方向.
[1] |
Marrero M, Urbano J, Sánchez-Cuadrado S, et al. Named entity recognition: Fallacies, challenges and opportunities. Computer Standards & Interfaces, 2013, 35(5): 482-489. |
[2] |
付瑞吉. 开放域命名实体识别及其层次化类别获取[博士学位论文]. 哈尔滨: 哈尔滨工业大学, 2014.
|
[3] |
Durrett G, Klein D. A joint model for entity analysis: Coreference, typing, and linking. Transactions of the Association for Computational Linguistics, 2014(2): 477-490. |
[4] |
Bhagavatula M, GSK S, Varma V. Named entity recognition an aid to improve multilingual entity filling in language-independent approach. Proceedings of the First Workshop on Information and Knowledge Management for Developing Region. 2012. 3-10. [doi: 10.1145/2389776.2389779]
|
[5] |
杨锦锋, 于秋滨, 关毅, 等. 电子病历命名实体识别和实体关系抽取研究综述. 自动化学报, 2014, 40(8): 1537-1562. |
[6] |
Nadeau D, Sekine S. A survey of named entity recognition and classification. Lingvisticæ Investigationes, 2007, 30(1): 3-26. |
[7] |
王宁, 葛瑞芳, 苑春法, 等. 中文金融新闻中公司名的识别. 中文信息学报, 2002, 16(2): 1-6. DOI:10.3969/j.issn.1003-0077.2002.02.001 |
[8] |
Han LF, Wong DF, Chao LS. Chinese Named Entity Recognition with Conditional Random Fields in the Light of Chinese Characteristics. In: Kłopotek MA, Koronacki J, Marciniak M, et al., eds. Language Processing and Intelligent Information Systems. IIS 2013. Lecture Notes in Computer Science, vol 7912. Springer, Berlin, Heidelberg. 2013. 74–85. [doi: 10.1007/978-3-642-38634-3_8]
|
[9] |
邱泉清, 苗夺谦, 张志飞. 中文微博命名实体识别. 计算机科学, 2013, 40(6): 196-198. DOI:10.3969/j.issn.1002-137X.2013.06.042 |
[10] |
Zhou GD, Su J. Named entity recognition using an HMM-based chunk tagger. Meeting of the Association for Computational Linguistics. Philadelphia, PA, USA. 2002. 473–480.
|
[11] |
Liu S, Tang B, Chen Q, et al. Drug name recognition: approaches and resources. Information, 2015, 6(4): 790-810. DOI:10.3390/info6040790 |
[12] |
Graves A, Fernández S, Gomez F, et al. Connectionist temporal classification: Labelling unsegmented sequence data with recurrent neural networks. International Conference on Machine Learning. ACM. New York, NY, USA. 2006. 369–376
|
[13] |
刘玉娇, 琚生根, 李若晨, 等. 基于深度学习的中文微博命名实体识别. 四川大学学报(工程科学版), 2016(S2): 142-146. |
[14] |
Nothman J, Ringland N, Radford W, et al. Learning multilingual named entity recognition from Wikipedia. Artificial Intelligence, 2013(194): 151-175. DOI:10.1016/j.artint.2012.03.006 |
[15] |
Hinton GE, Salakhutdinov RR. Reducing the dimensionality of data with neural networks. Science, 2006, 313(5786): 504. DOI:10.1126/science.1127647 |
[16] |
Bengio Y. Learning deep architectures for AI. Foundations & Trends® in Machine Learning, 2009, 2(1): 1-55. DOI:10.1561/2200000006 |
[17] |
Dahl GE, Dong Y, Li D, et al. Context-dependent pre-trained deep neural networks for large-vocabulary speech recognition. IEEE Transactions on Audio Speech & Language Processing, 2012, 20(1): 30-42. DOI:10.1109/TASL.2011.2134090 |
[18] |
Bahdanau D, Cho K, Bengio Y. Neural machine translation by jointly learning to align and translate. arXiv: 1409.0473.
|
[19] |
Mikolov T, Karafiát M, Burget L, et al. Recurrent neural network based language model. INTERSPEECH 2010, Conference of the International Speech Communication Association. Makuhari, Chiba, Japan. 2010. 1045–1048.
|
[20] |
Mikolov T, Kombrink S, Burget L, et al. Extensions of recurrent neural network language model. 2011 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP). Prague, Czech Republic. 2011. 5528–5531. [doi: 10.1109/ICASSP.2011.5947611]
|
[21] |
Labeau M, Löser K, Allauzen A, et al. Non-lexical neural architecture for fine-grained pos tagging. Proceedings of the 2015 Conference on Empirical Methods in Natural Language Processing. 2015. 232–237.
|
[22] |
Read J, Perezcruz F. Deep learning for multi-label classification. Machine Learning, 2014, 85(3): 333-359. |
[23] |
Ling W, Luís T, Marujo L, et al. Finding function in form: Compositional character models for open vocabulary word representation. arXiv: 1508.02096.
|
[24] |
Chiu JPC, Nichols E. Named entity recognition with bidirectional LSTM-CNNs. arXiv: 1511.08308.
|
[25] |
Hochreiter S, Schmidhuber J. Long short-term memory. Neural Computation, 1997, 9(8): 1735-1780. |
[26] |
Srivastava N, Hinton GE, Krizhevsky A, et al. Dropout: A simple way to prevent neural networks from overfitting. Journal of Machine Learning Research, 2014, 15(1): 1929-1958. |