基于正文和评论交互注意的微博案件方面识别*

2022-06-23 03:26郭军军余正涛
计算机工程与科学 2022年6期
关键词:正文编码注意力

段 玲,郭军军,余正涛,相 艳

(1.昆明理工大学信息工程与自动化学院,云南 昆明 650500;2.昆明理工大学云南省人工智能重点实验室,云南 昆明 650500)

1 引言

近年来网民对于法律案件的关注度增加,特别是特大重大案件的评审工作,已经成为互联网关注的热点,微博媒体对此类案件的报道愈加频繁,并且有很多网民对此发表评论。目前这类新闻的文本较多,面对庞大的数据,通过人工阅读大量评论来把握舆论动向是不现实的,而且民众和司法机关往往关注案件的不同方面。因此,面向微博涉案数据的方面识别研究对迅速掌握互联网态势具有重要的研究意义。

但是,微博数据形式和表述方式通常灵活多变,基于传统自然语言处理技术的方法进行微博案件观点所涉方面的判别较为困难。事实上,微博正文是对案件事实的陈述,包括对案件各方面的描述,微博评论大都是围绕正文内容展开的讨论,因此结合正文的信息能够对涉案文本的理解提供帮助。例如,“丽江反杀案”的微博文本示例如表1所示。

Table 1 Microblog case text

对于刑事案件,民众关注的焦点一般聚焦在:嫌疑人、被害人、案由和其他四个方面,并且通过分析微博案件数据,证实了以上四个方面的可靠性。以“丽江反杀案”为例,评论1中提到两个“谁”,仅凭此条评论识别所包含的方面,并且明确这两个“谁”分别指代哪个对象是有困难的。根据正文中“李某湘持刀砸门,90后退伍女兵唐雪将其反杀”,可以明确第一个“谁”指代李某湘,第二个“谁”指代唐雪,评论中包含嫌疑人和被害人两个方面。根据正文中“唐雪开门,被挣扎中的李某湘踹了一脚,唐雪便扑上来,两人扭打到了一起”,可以知道评论2描述的是案发的过程和原因,除了嫌疑人和被害人,还包含案由共三个方面。根据正文中“检察院通知律师说以故意伤害防卫过当起诉”,可以知道评论3提及的是其他的方面。

微博案件的方面识别就是将网民对司法案件的评论映射到上述四个不同的方面,但是由于评论中包含一方面或者多方面的信息,所以微博案件方面识别通常归类为文本多标签分类问题。然而,社交新闻媒体通常形式和内容都灵活多变,给文本语义理解带来极大的困难,本文针对涉案微博文本观点所含方面的识别问题开展研究,提出一种基于案件相关微博正文和评论交互注意的案件方面识别方法。首先基于Transformer框架对正文和评论分别进行编码;然后基于交互注意力机制,实现正文信息和评论信息的融合;最后基于融合后的特征实现对评论文本案件方面的识别。其具体内容性为:

(1) 提出一种文本多标签分类的模型,解决了微博案件的方面识别问题;

(2) 提出了融合正文信息和评论信息的交互注意力机制,提升和增强了评论的语义表征;

(3) 构建了一个刑事案件微博数据集,并基于该数据集验证了所提评论交互注意力机制的有效性。

2 相关工作

方面识别就是要自动识别出一条特定文本评论中粒度最细的评价对象。根据目前的研究工作,可以将方面识别的方法分为传统机器学习方法和基于深度学习的方法。

传统机器学习方法中,Hu等[1]融合评论文本词性信息,基于Apriori算法实现评论文本高频名词和名词短语的自动挖掘。其他典型的机器学习方法有隐马尔可夫模型HMM(Hidden Markov Model)、条件随机场模型CRF(Conditional Random Field)等。如Jin等[2]采用一种编入词汇的HMM模型来提取显式方面;Zhang等[3]在带监督学习的条件随机场模型中引入词性等特征进行训练,并构建相应领域词典,利用该词典识别产品方面。上述的研究工作多为有监督的学习方法,大多数无监督方法基于LDA(Latent Dirichlet Allocation)及其变体,例如,文献[4,5]将主题信息作为方面词项,实现方面信息的挖掘。然而,LDA并不能很好地从短评论中找到连贯的主题,而且,即使主题和方面可能重叠,也不能保证它们是相同的。

近年来,深度学习方法在方面识别任务中取得了不错的成绩。He等[6]提出了一种无监督的神经网络结构ABAE(Attention-based Aspect Extraction),利用预先训练好的词嵌入来增强主题的连贯性,通过重构损失从词嵌入空间中学习各个方面的嵌入。Angelidis等[7]提出了MATE(Multi-Seed Aspect Extractor),它使用一些与方面相关的种子词的嵌入来确定ABAE中的方面嵌入。Zhao等[8]借用方面嵌入和种子词的想法,提出了一个生成模型,能自动地从外部信息中收集种子词。除此之外,有部分学者将方面识别当作一个文本序列标注问题,如Poria等[9]提出一种基于七层深度卷积网络的模型来对句子进行标记训练,从而识别方面。也有学者将方面识别转化为文本分类问题,如Liu等[10]提出一种文本分类模型,用于识别产品评论中所包含的方面,并且取得了不错的效果。基于卷积神经网络CNN(Convolutional Neural Network)和循环神经网络RNN(Recurrent Neural Network)的深度学习网络结构在社交媒体文本分类任务中效果显著,但不足之处是不够直观,解释性不好。而注意力机制[11]能够很直观地给出每个词对结果的贡献,如Yang等[12]提出的分层注意网络(Hierarchical Attention Network)。Transformer[13]仅依靠注意力机制,能够比神经网络更快速地获取文本特征表达。近年来,有部分学者结合更为丰富的信息对文本进行分类,如Chai等[14]将标签类别与类别描述相关联,类别描述由手工制作的模板或使用从强化学习中所提取的抽象模型生成,使分类模型关注与标签描述相关的最显著文本。Wang等[15]提出了一种标签嵌入注意模型,将词和标签联合嵌入在一潜在空间中,直接利用文本标签的兼容性构造文本表示。Sun等[16]在基于方面的情感分析ABSA(Aspect-Based Sentiment Analysis)任务中使用四种不同的句子模板构造辅助句,将ABSA转化为句子对分类任务。与单标签分类不同,多标签分类给一个数据样本标注多个标签,能够更加准确、有效地表达多重语义信息。通常一条特定文本评论中包含多个评价对象,因此方面识别任务更类似于文本多标签分类的问题。基于深度学习的多标签分类模型尚处于研究阶段。Kurata等[17]使用CNN进行分类,Chen等[18]使用CNN级联RNN获取文章的语义信息。Yang等[19]提出将序列到序列模型应用到多标签分类中,序列生成模型SGM(Sequence Generation Model)把标签相关关系考虑在内,并且提出一个新的解码结构的序列生成模型,能够捕获标签之间的相关关系,而且在预测的时候自动选择信息量最丰富的词。Yang等[20]基于卷积神经网络对文本进行表征,并利用自注意力机制实现文本信息的交互及特征提取,以从源文本中提取细粒度的局部邻域信息和全局交互信息。 Xiao等[21]提出了一个标签特定注意网络LSAN(Label-Specific Attention Network),LSAN利用标签语义信息来确定标签和文档之间的语义联系,同时采用自注意力机制从文档内容信息中识别标签特定的文档表示形式。

针对微博评论通常包含多方面观点,微博案件的评论都是围绕微博正文展开讨论,微博正文能给评论的语义理解提供帮助的特点,本文提出一种基于正文和评论交互注意的多标签分类模型,用于识别案件的方面。

3 基于正文和评论交互注意的案件方面识别方法

本文提出一种基于微博正文和评论交互注意思想的微博案件方面识别方法,通过自注意力机制,实现对正文和评论的编码,基于交互注意力机制,实现正文和评论的融合。具体网络结构如图1所示。

Figure 1 Network structure of aspect identification based on the contents and comments interactive attention network图1 基于正文和评论交互注意力网络的案件方面识别网络结构

本文融合正文和评论的案件方面识别模型主要由三个部分组成:基于自注意力机制的正文和评论编码、正文和评论交互注意力编码网络和案件方面识别。(1)基于自注意力机制的正文和评论编码。微博案件的正文和评论作为模型两端的输入,对正文和评论采用同样的编码方式,将正文和评论分别进行表征,得到正文和评论的嵌入矩阵;然后采用多头注意力机制对其编码,计算句子中的每个词与所有词的关注。(2)正文和评论交互注意力编码网络包括3个模块:①正文到评论的编码模块表示哪些正文词与每个评论词最相关;②评论到正文的注意力编码模块表示哪些评论词与每个正文词最相似;③交互注意融合模块,通过正文和评论互相关注,融合正文和评论信息,得到包含有正文信息的评论的表征。(3)案件方面识别。对融合后的特征通过线性变换和sigmoid函数,将评论映射到相应的标签,得到案件方面识别的结果。

3.1 正文和评论交互注意力编码

正文和评论交互注意力编码包括两个模块:基于自注意力机制的正文和评论编码、正文和评论交互注意力编码网络。对正文和评论采用自注意力机制的方式进行编码,得到关于正文和评论的两个表征,再通过交互注意力机制对这两个表征进行融合,得到包含有正文信息的评论语义表征。

3.1.1 基于自注意力机制的正文、评论编码

正文和评论自注意力编码将微博案件的正文和评论作为编码端的两个输入。假设一个句子,其中有n个词,可以将其用序列来表示,则正文和评论分别用式(1)和式(2)表示:

L=(l1,l2,…,ln)

(1)

K=(k1,k2,…,kn)

(2)

其中,L和K分别表示正文和文本的序列,n为序列长度。

对输入的句子序列进行词嵌入,得到词嵌入序列表示,如式(3)和式(4)所示:

EL=(wl1,wl2,…,wln)

(3)

EK=(wk1,wk2,…,wkn)

(4)

其中,EL和EK是将正文和评论句子表示成一个二维嵌入矩阵的序列,它将句子的所有嵌入连接在一起,其维度大小为n×d,n是词的个数,d为句子嵌入的维度。序列中的每个元素都是相互独立的。

使用多头注意力机制读取每个文本序列并计算每个词与所有词的关注。将二维嵌入矩阵EL和EK转化为查询(Q)、键(K)和值(V),并对其进行线性变化后输入到头数为8的多头注意力机制中;然后将所有头的输出值进行拼接;最后通过线性变换层转换成和单头一样的输出值,如式(5)和式(6)所示:

AL=Linear(MH(QL,KL,VL))

(5)

AK=Linear(MH(QK,KK,VK))

(6)

其中,矩阵AL和AK分别表示基于多头注意力网络表征后的正文和评论表征向量。

基于多头注意交互的文本语义表征对每个词进行词嵌入得到关于句子的嵌入矩阵,对嵌入矩阵分别进行线性变换得到相应的查询(Q)、键(K)和值(V)。Q、K和V为三个完全相同的语义特征向量,分别经过一次线性变换,然后同时并行进行h次点积注意交互运算,也就是所谓的多头,头之间参数不共享,每次Q、K和V进行线性变换的参数都是不一样的。然后将h次缩放点积注意的结果进行拼接,再进行一次线性变换后得到的值是多头注意力机制的结果,如式(7)所示:

MH(Q,K,V)=Concat(head1,head2,…,headh)Wo

(7)

(8)

(9)

3.1.2 正文和评论交互注意编码网络

正文和评论交互注意编码的思想受Seo等[22]在机器阅读理解任务上提出的双向注意力流BiDAF(Bi-Directional Attention Flow)的启发。正文和评论交互注意力编码网络负责链接和融合正文和评论的信息,编码结构如图2所示,其中,K={K1,…,Ki,…,KT}表示基于正文加权后的评论文本表征,i=1,…,T表示文本序列序号。

Figure 2 Structure of the contents and comments interaction attention coding network图2 正文评论交互注意力编码网络结构

正文和评论交互注意力编码网络包括三个模块:正文到评论的注意力编码模块、评论到正文的注意力编码模块和交互注意融合模块。

交互注意力编码模块的输入是经过多头注意力机制编码得到的正文和评论的表征。编码网络从两个方向计算关注:从评论到正文的关注和从正文到评论的关注,这两个关注来自于正文和评论的上下文嵌入信息之间的共享相似度矩阵S,相似度矩阵计算如式(10)所示:

Stj=α(AK:t,AL:j)

(10)

其中,Stj表示第t个评论词和第j个正文词之间的相似度;α(·)表示可训练标量函数,编码两个输入向量之间的相似度;AK:t表示AK的第t列向量,AL:j表示AL的第j列向量。

(1)正文到评论的注意力编码模块。正文到评论的关注表示哪些正文词与每个评论词最相关。令at表示所有的正文词与第t个评论词之间的注意力权重向量,对于所有的t,∑tatj=1。注意力权重通过at=softmax(St:)计算求得,则每个参与关注的正文向量表示如式(11)所示:

U=∑jatjAL:j

(11)

其中,U中包含了同所有评论词计算关注的正文向量。

(2)评论到正文的注意力编码模块。评论到正文的注意力表示哪些评论词与每个正文词最相似。通过p=softmax(maxcol(S))来获得评论词的注意力权值,其中求最大值的函数maxcol(S)是跨列执行的。则每个参与关注的评论向量基于加权平均后的表示如式(12)所示:

U′=∑tptAK:t

(12)

其中,t为正文文本序列序号,pt表示第t个词的注意力权值,U′表示某一时刻与正文最相关的评论词的权重和。

(3)交互注意融合模块。交互注意融合模块最后将评论词嵌入和正文评论交互式注意向量进行拼接,得到的矩阵用G来表示,如式(13)所示:

G=β(K,U,U′)

(13)

其中,G中的每个列向量可以被看作是每个评论词有正文信息的表征,β(·)是任意可训练的神经网络,它融合了三个输入向量。

3.2 融合正文和评论交互注意信息的案件方面识别

3.2.1 方面识别

通过正文和评论相互关注的过程,融合正文和评论交互注意信息得到的矩阵G是包含有正文信息的评论表征。将这个表征经过一个四层的线性变换和一个非线性激活函数,可得到四个类的向量F。再通过sigmoid函数对每个类进行二分类,将四个类的向量映射到(0,1),得到类别预测矩阵P。分类过程如式(14)和式(15)所示:

F=tanh(Linear(G))

(14)

P=sigmoid(F)

(15)

当评论的类别预测结果Pi,j大于阈值0.47时,则认为该评论属于该类别;反之则不属于。将每条评论映射到一类或多类,可实现微博案件方面的识别。

3.2.2 损失函数

本文使用汉明损失HL(Hamming Loss)来评估模型的精度。汉明损失统计了被误分类的样本数,即不属于这个类别的标签被预测,或者属于这个类别的标签没有被预测。汉明损失的值越小,性能越好。对于一个测试集X={(x1,Y1),(x2,Y2),…,(xn,Yn)},其损失计算如式(16)所示:

(16)

其中,n是样本的数量,L是标签的数量,Yi表示第i个样本的真实类别标签,Pi表示第i个样本的类别预测标签。XOR(·)表示异或运算,且满足XOR(0,1)=XOR(1,0)=1,XOR(0,0)=XOR(1,1)=0。

4 实验

本节首先介绍本文提出的数据集、实验参数、评价指标、实验细节和所有的基线方法;然后,将本文方法与基线方法进行比较,并通过消融实验验证文本和评论的双向交互注意力模块的有效性;最后,对实验结果进行分析和讨论。

4.1 数据集

本文从微博爬取了12个热点案件的7 000条数据,每条数据均包含一个正文及相应的一条评论。在7 000条数据中,2 973条数据包含对嫌疑人的评价,1 872条数据包含对被害人的评价,879条数据包含对案由的评价,3 772条数据包含对其他方面的评价。大部分的评论数据有2个标签,部分数据有3或4个标签,少部分数据有1个标签,平均标签数约为2个。按照8∶1∶1的比例划分数据集,训练集、验证集和测试集中均包含12个案件的数据,其中训练集5 600条,验证集和测试集各700条。

4.2 实验参数设置

本文使用PyTorch深度学习框架编码模型。微博案件文本的词向量维度为512维,词表大小为3 076。多头注意力机制中的dmodel大小为512维,头数h为8。交互式注意力机制融合正文和评论信息,对得到的交互注意信息矩阵进行四层线性变换,预测到四个类别,然后使用sigmoid函数输出标签空间上的概率分布。其中每层线性变换的隐藏单元数为128。模型的学习率设置为0.000 3,随机失活率设置为0.5。

4.3 基线方法

针对本文所提出的数据集,本文设置了以下几个对比实验。基线方法的对比实验均不融合案件正文信息。

(1)CNN[17]:使用多个卷积核提取微博案件评论文本特征,输入到线性变换层,然后输出标签空间上的概率分布。

(2)CNN-RNN[18]:利用CNN和RNN获取全局和局部的案件评论文本语义,并对标签相关性进行建模。

(3)Transformer[13]:在文本分类中只用到Transformer的编码端,获取微博案件评论的文本特征,再输出标签的概率。

(4)ABAE[6]:将词共现统计数据显式地编码为词嵌入,使用降维方法提取评论语料中最重要的方面,并通过方面嵌入的线性组合来重构每个句子,使用注意力机制去除不相关的词,以进一步提高各方面的连贯性。

4.4 实验分析

4.4.1 评价指标

本文采用准确率P(Precision)、召回率R(Recall)和Weigthed-F1值作为所提方法有效性的评价指标。

Weight-F1的计算方法为:先计算出每一个类别的P、R和F1,然后通过求均值得到整个样本集上的F1值。在此基础上,再根据每一类别的数据大小进行加权平均。

4.4.2 对比实验

在本文所提出的数据集上,本文所提方法与不同基线方法进行了对比实验,实验结果如表2所示。

Table 2 Experimental results of different approaches aspects identification

表2的实验结果表明,在本文所提出的数据集上,相比基线方法,本文所提方法通过交互注意力机制融合正文信息,在主要评价指标上性能最好。本文提出的基于正文和评论交互注意的方面识别方法,与最常用的CNN方法相比,准确率提高了3.83个百分点,召回率提高了3.32个百分点,F1值提高了2.16个百分点。相比于CNN-RNN方法,本文所提方法精确率提高了5.05个百分点,召回率提高了1.51个百分点,F1值提高了2.53个百分点。本文只使用了Transformer模型中的多头注意力部分,采用Transformer模型的编码端对评论进行编码,然后对其进行多标签分类。相比之下,本文所提方面识别方法在准确率上提高了3.17个百分点,召回率提高了3.76个百分点,F1值提高了3.77个百分点。基于LDA的无监督方法难以从评论中获取连贯的主题。ABAE是方面提取的经典方法,对于本文所使用的数据集,ABAE模型首先将微博案件的评论数据通过word2vec训练成词向量,使用注意力层关注句子中最重要的信息,实验结果准确率为73.43%,召回率为87.29%,F1值为79.19%。由表3可知,ABAE没有融入正文信息,本文所提方法在方面识别性能上优于ABAE方法。

由此可见,本文通过融合正文信息的方式,增强了评论的语义表征,使分类的性能得到了提升。

此外,本文构建的数据集中包含嫌疑人和其他的评论较多,包含案由的评论较少,存在数据不均衡的问题,因此还计算了每一类的准确率、召回率和F1值。各类别的有效性验证结果如表3所示。

Table 3 Effectiveness verification results of each category

分析表3可得,嫌疑人、被害人和其他的评论数量较大,其F1值较高,案由评论数量较少,其F1值较低,但在加权平均后对总体的F1值影响较小。

4.4.3 消融实验

为验证本文所提方法的有效性,本节将交互注意力层消去进行比较。

在表4中,“消去交互注意力网络”表示去掉正文和评论交互注意力网络,“消去评论到正文注意力编码”表示交互注意力网络中只保留正文到评论的注意力,“消去正文到评论注意力编码”表示交互注意力网络中只保留评论到正文的注意力。分析表4实验结果可知,通过交互注意力的方式融合正文的信息,增强了评论的语义表征,同时,相比于单向的关注,双向关注对评价对象方面识别的性能有明显的提升。

Table 4 Results of ablation experiment

4.4.4 案例分析

在对不同标签进行预测时,不同词语的贡献也存在差异。表5给出几个例子的注意力层可视化,表6给出这几个例子使用不同方法得到的相应标签。当预测标签“嫌疑人”时,它可以自动为信息更丰富的词分配更大的权重,比如十四岁、男孩和施暴者等。对于标签“被害人”,所选的信息词为十一岁、女孩和受害者等。对于标签“案由”,所选的信息词为性侵和杀人等。对于标签“其他”,所选的信息词为正文中除上述三方面外的关键词、正文中没有出现的信息词等。这表明本文所提方法在预测不同的标签时,能够自动在评论中选择信息最丰富的词语。

Table 5 Visualization of interactive attention mechanism

Table 6 Examples of label generation

以表5中的3条评论生成的标签序列为例,将本文方法与最常用的基线方法CNN进行了比较,结果如表6所示。与真实标签相比,CNN模型能够预测评论1这样信息词比较明显的相关标签,然而因为未加入正文信息,CNN在预测评论2时没有预测出完整的标签,在预测评论3时甚至出现了错误。消去交互注意力机制导致方法没有正文信息,会出现与CNN模型一样的相关标签预测不完整或者错误的问题。本文所提方法融合了正文的信息,可以准确地预测出评论1和评论2这样信息词较为明显的标签,在预测评论3时,由于主语不明确,模型预测出现了错误。但是,总体而言,本文所提方法由于融入了正文信息,增强了评论的语义表征,相比于其他方面识别方法,预测标签的准确率有明显的提升。

5 结束语

针对微博案件观点所涉方面的智能识别问题,本文提出一种基于微博案件正文和评论交互注意力的多标签分类方法,实现对微博案件评论文本中方面的自动识别。通过与基线方法进行比较、消去交互注意力机制各项实验,结果表明交互注意力机制融合了正文信息,对评论中方面的自动识别有良好的效果。

猜你喜欢
正文编码注意力
让注意力“飞”回来
生活中的编码
更正启事
科技论文正文书写的要求
《全元诗》未编码疑难字考辨十五则
如何培养一年级学生的注意力
子带编码在图像压缩编码中的应用
Genome and healthcare
A Beautiful Way Of Looking At Things
户口本