如何理解用户评论中的细粒度情感?面向目标的观点词抽取

2024-03-02 03:59

本文主要是介绍如何理解用户评论中的细粒度情感?面向目标的观点词抽取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


「论文访谈间」是由 PaperWeekly 和中国中文信息学会社会媒体处理专委会(SMP)联合发起的论文报道栏目,旨在让国内优质论文得到更多关注和认可。


背景介绍

文本情感分析旨在自动地从非结构化的评论文本中抽取有用的观点信息 [1,2] 。早先的文本情感分析工作主要关注文档级别的情感分析和句子级别的情感分析,采用各种方法来分析评论文档或句子整体的情感极性(如正面、负面、中性)。

不同于文档 / 句子级情感分析,细粒度情感分析(Aspect-Based Sentiment Analysis,ABSA)的目的在于分析评论文本中商品 / 服务的具体方面(aspect)的情感 [3] 。

举个例子,用户在某条餐厅评论中 “waiters are unfriendly but the pasta is out of this world.”,对 “waiters” 和 “pasta” 两个方面分别表达了负面的情感和正面的情感。普通的文档 / 句子级情感分析并不能完成这种细粒度的分析任务,ABSA 也因此成为近些年情感分析的热点研究问题。

典型的 ABSA 能够帮助分析评论文本中具体方面的情感极性(正面、负面、中性),但无法提供用户在每个方面的具体观点,如上例中 “waiters” 是 “unfriendly” 的,“pasta” 是 “out of this world” 的。显然,这些观点词解释了用户对某些方面产生相应情感的原因。

为此,我们提出了一个新的细粒度情感分析子任务——面向目标的观点词抽取(Target-oriented Opinion Words Extraction,TOWE),旨在从评论文本中抽取出给定目标(target)对应的观点词(opinion words)。

在 TOWE 任务中,目标对象(target)是提前给定的,和 aspect 表达了相同的含义,都是指评论文本中商品/服务的具体方面 / 属性。以上面的句子为例,当给定目标是“waiters”时,TOWE 需要抽取 “unfriendly” 作为 “waiters” 的观点词;当给定目标为 “pasta”,TOWE 则会抽取观点词 “out of this world”。

这个任务有很多潜在的应用,如给出每个方面具体的观点信息从而帮助商家提升相应的服务、自动从评论中生成成对的观点摘要、帮助我们理解评论中用户情感的来源和提升 aspect-level sentiment classification 的性能。

在接下来的章节中,我们首先给出 TOWE 任务的形式化定义以及我们构造的 benchmark 数据集,然后介绍我们在 NAACL19 和 AAAI20 上的两项工作。

NAACL19 “Target-oriented Opinion Words Extraction with Target-fused Neural Sequence Labeling” [4] 这篇工作定义了 TOWE 任务,并且给出一个鲁棒的融合目标信息的神经序列化标注模型。

论文标题:Target-oriented Opinion Words Extraction with Target-fused Neural Sequence Labeling

论文来源:NAACL 2019

论文链接:https://www.aclweb.org/anthology/N19-1259

代码链接:https://github.com/NJUNLP/TOWE

考虑到标注大量细粒度情感分析数据是耗时且困难的,AAAI20 中的工作 “Latent Opinions Transfer Network for Target-Oriented Opinion Words Extraction” [5] 从迁移学习的角度出发,提出潜在观点迁移网络,从资源丰富的评论情感分类数据中迁移潜在观点知识来辅助提升 TOWE。

论文标题:Latent Opinions Transfer Network for Target-Oriented Opinion Words Extraction

论文来源:AAAI 2020

论文链接:https://arxiv.org/abs/2001.01989

代码链接:https://github.com/NJUNLP/TOWE

任务定义 & 数据集

在评论文本中,一个目标对象可能有多个观点词,如 “dessert are not outstanding but good.” 中 “dessert” 有两个 opinion words,分别是 “not outstanding” 和 “good”。

为了将这种复杂且边界不确定的一对多关系转换成可以解决的问题,我们结合给定的 target,将 TOWE 形式化为一个给定目标的序列标注任务(target-oriented sequence labeling),并按照 {B, I, O} 标注方案标注观点词。

图 1 展示了句子 “waiters are unfriendly but the pasta is out of this world.” 在给定不同 targets 时的标注结果,粗体标出了给定的 targets,斜体表示的是 target 对应的观点词。

▲ 图1:TOWE标注样例

我们基于 SemEval14、SemEval15 和 SemEval16 的 ABSA 数据集构造了 TOWE 数据集。原始的 ABSA 数据集只提供 target 和对应情感极性的标注,没有标注 target 对应的观点词。

因此我们手工标注了每个样例中 target 对应的观点词,并删去了没有显性观点词的样例,最终构造出了四个新的数据集。数据集的统计信息如下表所示,“res” 和 “lap” 表示评论文本分别来自餐馆领域(restaurant)和笔记本领域(laptop):

▲ 表1:TOWE数据集统计信息

融合目标信息的神经序列化标注模型

不同于普通的序列化标注任务,TOWE 的难点在于对同一个句子,如果输入的目标对象不同,那么对应标注的观点词也应该不同。

容易想到,问题核心在于如何建模 target 和上下文之间的语义关系,从而得到 target-specific 的文本表示。受模型 TD-LSTM [6] 的启发,我们以 LSTM 作为基础组件,设计了一个融合目标信息的神经序列化标注模型 IOG。

IOG 采用 encoder-decoder 框架,encoder 中包含了三个组件,分别是 Inward-LSTM,Outward-LSTM 和Global LSTM。我们根据目标对象的位置将评论句子分为三个部分:上文、target、下文。

Outward-LSTM 由两个方向相反的 LSTM,从句子中间的目标对象分别向上文和下文建模(自内向外),从而将目标信息传入到它的上下文中,生成 target-specific 的表示。和 Outward-LSTM 相反,Inward-LSTM 采用两个方向向内的 LSTM 分别从句子两端向目标位置编码(自外向内)。

此外,为了弥补切分上下文带来的句子信息的分隔和不完整,我们引入 Global LSTM 来建模句子的整体语义,即用一个普通的 BiLSTM 编码完整的句子表示。最终,我们将 Inward-LSTM,Outward-LSTM 和 Global LSTM 对应位置的表示进行拼接,得到 encoder 的表示。

在 decoder 端,我们使尝试了两种解码策略,一种是在每个位置独立的做三分类,优点是解码速度更快,第二种是使用 CRF 来考虑标签之间的依赖关系。具体模型如图 2 所示。

▲ 图2:IOG图例

我们采用 precision、recall 和 F1-score 来衡量不同模型的性能,并建立了一系列 baselines,包括规则方法和神经网络方法,主要实验结果如表 2 所示。

▲ 表2:主要实验结果

在上表中,Pipeline 方法表示先用 BiLSTM 做序列化标注,再根据距离规则,将标注结果中离目标最近的观点词作为其对应的结果。TC-BiLSTM 将 target 表示和句子中每个词向量进行拼接,然后用 BiLSTM 编码。

可以看到,我们的方法大幅超过了两个基于规则的算法,表明基于监督学习的序列化标注方法比规则模板要更加鲁棒,更能捕捉复杂的语义信息。

此外,IOG 也大幅超过了没有融入目标信息的模型 BiLSTM 和简单拼接 target 表示的神经序列化标注模型 TC-BiLSTM,这说明我们的模型可以更好地建模目标对象和上下文之间的语义关系,从而学习 target-specific 的文本表示。为了分析模型各个模块的功能,我们也做了模型各个变种的对比实验,具体结果见表 3。

▲表3:模型变种实验结果

上表表明,Outward-LSTM 显著优于 Inward-LSTM。这是因为 Outward-LSTM 对于句子中的每个位置生成的都是 target-specific 的表示,而 Inward-LSTM 在多 targets 的句子中,对 targets 外侧的表示是相同的,这意味即使给定 target 不同,这部分的标注结果也是相同的。

Global-LSTM 进一步提升了模型新能,CRF 在这个任务上的提升很微弱。

潜在观点迁移网络

如前面提到的,细粒度情感分析的数据标注是复杂且耗时的,因为标注者需要标出评论中所有的目标对象以及它们对应的观点词和情感极性,这导致我们很难获取大规模的标注样本,数据不足严重制约了神经网络模型在 TOWE 任务上的性能。

相比之下,我们很容易从在线评论网站中获取大量的带有情感标签的评论情感分类数据。这些数据中包含了大量的潜在观点信息以及与情感相关的语义模式。因此,我们从迁移学习的角度出发,提出迁移评论情感分类数据中的潜在观点来提升 TOWE 任务的性能。

在迁移之前,有两个挑战需要解决。首先,评论情感分类数据中的观点信息(如观点词)是未标注的,我们需要显示地找出这些潜在的观点信息。其次,评论情感分类只考虑文本整体的情感极性,不涉及具体的目标对象。

因此,在第一步找出全局的观点信息之后,我们需要将其转化成目标相关的观点信息,然后才能融合到 TOWE 任务中。

为了解决迁移过程中的两个挑战,我们设计了一个潜在观点迁移网络(Latent Opinion Transfer Network,LOTN),如图 3 所示。LOTN 主要包含两个模块,左边的模块用来解决 TOWE 任务,右边是预先训练的评论情感分类模块。

▲ 图3:LOTN图例

具体而言,我们先在大规模评论情感分类数据集上预训练一个 attention-based BiLSTM 网络,作为预训练的情感分类模型。在预训练的情感分类模型中,注意力机制用来捕获文本中潜在的观点。

可以想到,注意力权重越大的词越有可能是观点词,因此注意力权重可以用来指示潜在的观点词。为了解决上述的第二个挑战,我们设计了一个启发式规则,将情感分类模型中每个词的注意力权重乘以一个与目标对象相关的系数,从而将全局的注意力权重转化成目标相关的注意力权重。

系数大小根据每个词与目标对象之间的距离计算得出,距离目标对象越近的词系数越大。因为根据修饰关系以及语义表达上的相关性,和目标对象越接近的词越有可能是其对应的观点词,观点词出现在较远位置的概率会低很多。

然后,我们通过一个阈值,将目标相关的注意力权重转化成 0/1 分布的潜在观点词标签,并通过辅助学习信号将这些潜在的观点词信息融合到 TOWE 任务中。预训练情感分类模型中的 BiLSTM 层包含着大量情感相关的语义模式,我们也将它拼接到 TOWE 模块的 encoder 中。

为了预训练评论情感分类模型,我们从 Yelp 评论网站和 Amazon 评论网站获取共计 100 万条左右的评论数据。数据集统计信息如下表所示:

▲ 表4:评论情感分类数据统计信息

主要结果如表 5 所示,PE-BiLSTM 是我们基础的 TOWE 模型,即 LOTN 的 base 版本,表示不从情感分类数据集中迁移观点知识。

▲ 表5:LOTN和相关模型比较

可以看到,我们的潜在观点迁移网络 LOTN 相对 base 模型 PE-BiLSTM 取得了非常显著的提升。相比于之前的 state-of-the-art IOG,LOTN 也获得了比较明显的提升。我们也测试了迁移 encoder 和迁移潜在观点词对 TOWE 任务带来的性能增益,结果如表 6 所示。

▲ 表6:迁移encoder和潜在观点词的影响

相比于 base 模型 PE-BiLSTM,迁移 encoder 或者潜在观点词都获得了明显的性能提升,这表明两种方案都能捕获情感分类数据中潜在的观点信息,并为 TOWE 所用。融合两者之后,结果获得了进一步提升,说明两者从不同角度迁移了观点知识。

为了分析 base 模型 PE-BiLSTM 和最终模型 LOTN 的不足之处,我们在数据集 14res 上进行了错误统计分析,结果见表 7。

“NULL” 表示抽取结果为空,即模型没有抽取任何观点词;“under-extracted” 表示模型只抽取了真实观点词的一部分;“over-extracted” 则表示除真实观点词外模型还抽取了其他的词。

▲ 表7:PE-BiLSTM和LOTN在14res上的错误类型统计

可以看到,在迁移情感分类数据集中的潜在观点知识之后,LOTN 在空预测和 “under-extracted” 上的错误更少,在 “over-extracted” 上的错误变多。这三者一致地表明,在迁移观点的影响下,LOTN 倾向解码出更多的观点词。

实际上,“NULL” 和 “under-extracted” 两类错误都属于抽取不足,表 7 的结果也表明抽取不足可能是 TOWE 任务的主要错误。

总结

面向目标的观点词抽取(TOWE)不仅能提供更加细致可解释的观点分析,也能为相关的情感分析任务带来帮助。为了研究它,我们形式化地定义了 TOWE任务,并且给出了四个 benchmark 数据集。

此外,我们就如何有效地融合目标信息以及缓解资源稀缺两个问题上做了初步的尝试。在后续的工作中,如何缓解神经网络模型在 TOWE 上抽取不足、以及如何利用 TOWE 提升其他的情感分析任务仍需进一步探索。

参考链接

[1] Pang, B., and Lee, L. 2008. Opinion mining and sentiment analysis. Foundations and Trends in Information Retrieval 2(1–2):1–135.

[2] Liu, B. 2012. Sentiment Analysis and Opinion Mining. Synthesis Lectures on Human Language Technologies. Morgan & Claypool Publishers.

[3] Pontiki, M.; Galanis, D.; Pavlopoulos, J.; Papageorgiou, H.; Androutsopoulos, I.; and Manandhar, S. 2014. Semeval 2014 task 4: Aspect based sentiment analysis. In SemEval@COLING 2014, 27–35.

[4] Fan, Z.; Wu, Z.; Dai, X.; Huang, S.; and Chen, J. 2019. Target-oriented opinion words extraction with target-fused neural sequence labeling. In NAACL-HLT, 2509–2518.

[5] Wu, Z., Zhao, F., Dai, X. Y., Huang, S., & Chen, J. 2020. Latent Opinions Transfer Network for Target-Oriented Opinion Words Extraction. In AAAI.

[6] Tang, D.; Qin, B.; Feng, X.; and Liu, T. 2016. Effective lstms for target-dependent sentiment classification. In COLING, 3298–3307.

关于作者

吴震,南京大学自然语言处理研究组博士研究生,主要研究方向为情感分析和迁移学习。在国际人工智能会议AAAI以及自然语言处理会议NAACL、NLPCC上共发表论文四篇;曾获2018年CCF大数据与计算智能大赛“汽车行业用户观点主题及情感识别赛题”一等奖(Top1/1701)和CCF最佳创新价值奖;在第八届全国社会媒体处理大会“拓尔思杯”中文隐式情感分析评测任务中获三等奖。

范志方,南京大学自然语言处理研究组硕士研究生,主要研究方向为情感分析和深度学习。在自然语言处理会议NAACL上发表论文一篇;曾获2018年CCF大数据与计算智能大赛“汽车行业用户观点主题及情感识别赛题”一等奖(Top1/1701)和CCF最佳创新价值奖。

赵飞, 南京大学自然语言处理研究组硕士研究生,主要研究方向为细粒度情感分析和迁移学习。在人工智能会议AAAI发表论文一篇。

戴新宇,南京大学教授、博士生导师,人工智能学院副院长。主要研究方向为自然语言处理。

点击以下标题查看更多往期内容: 

  • 变分推断(Variational Inference)最新进展简述

  • 变分自编码器VAE:原来是这么一回事

  • 图神经网络三剑客:GCN、GAT与GraphSAGE

  • 如何快速理解马尔科夫链蒙特卡洛法?

  • 深度学习预训练模型可解释性概览

  • ICLR 2020:从去噪自编码器到生成模型

#投 稿 通 道#

 让你的论文被更多人看到 

如何才能让更多的优质内容以更短路径到达读者群体,缩短读者寻找优质内容的成本呢?答案就是:你不认识的人。

总有一些你不认识的人,知道你想知道的东西。PaperWeekly 或许可以成为一座桥梁,促使不同背景、不同方向的学者和学术灵感相互碰撞,迸发出更多的可能性。 

PaperWeekly 鼓励高校实验室或个人,在我们的平台上分享各类优质内容,可以是最新论文解读,也可以是学习心得技术干货。我们的目的只有一个,让知识真正流动起来。

???? 来稿标准:

• 稿件确系个人原创作品,来稿需注明作者个人信息(姓名+学校/工作单位+学历/职位+研究方向) 

• 如果文章并非首发,请在投稿时提醒并附上所有已发布链接 

• PaperWeekly 默认每篇文章都是首发,均会添加“原创”标志

???? 投稿邮箱:

• 投稿邮箱:hr@paperweekly.site 

• 所有文章配图,请单独在附件中发送 

• 请留下即时联系方式(微信或手机),以便我们在编辑发布时和作者沟通

????

现在,在「知乎」也能找到我们了

进入知乎首页搜索「PaperWeekly」

点击「关注」订阅我们的专栏吧

关于PaperWeekly

PaperWeekly 是一个推荐、解读、讨论、报道人工智能前沿论文成果的学术平台。如果你研究或从事 AI 领域,欢迎在公众号后台点击「交流群」,小助手将把你带入 PaperWeekly 的交流群里。

这篇关于如何理解用户评论中的细粒度情感?面向目标的观点词抽取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/764843

相关文章

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念