论文标题:EANN: Event Adversarial Neural Networks for Multi-Modal Fake News Detection
论文链接:https://dl.acm.org/doi/abs/10.1145/3219819.3219903
论文来源:KDD 2018
一、概述
对于假新闻检测任务,现有方法仍然无法对新出现的、时效性强的假新闻做出有效检测。事实上现有方法容易学习到针对特定事件的特征,然而这些特征不一定会出现在其他事件中。这种特定于事件的特征虽然能够帮助对已验证事件的帖子进行检测,但会损害对新出现事件的检测精度。因此本文所提出的方法致力于学习事件之间能够共享的特征来进行假新闻的检测,目标就是移除不可迁移的特定于事件的特征,保留事件之间可共享的特征。
要想能够移除特定于事件的特征,首先就要去识别。对于事件之间不可共享的特定于事件的特征,可以通过测量对应不同事件的帖子之间的差异来检测。因此,识别特定事件的特征相当于测量不同事件中学习到的特征之间的差异。
本文提出的EANN(Event Adversarial Neural Networks)模型就是用来应对上述挑战,受对抗网络思想的启发,我们引入event discriminator来预测训练阶段的事件辅助标签(表明属于哪个事件的标签),并利用相应的损失来估计不同事件之间特征表示的差异。这个损失越大,不同事件的特征差异就越小。另外由于假新闻帖子通常包含文本和图片两种内容,因此EANN的特征提取器是多模态的。总体来说,EANN包括三个结构:multi-modal feature extractor,fake news detector,event discriminator。feature extractor和fake news detector相互配合来完成假新闻识别任务,同时feature extractor试图“欺骗”event discriminator来学习事件不变性特征。另外,EANN是一个通用的框架,其中的multi-modal feature extractor可以采用各种不同的网络架构。
二、方法
本文采用的模型架构基本上沿用这篇论文所提出的架构:反向传播的无监督域自适应方法。
- 框架
下图展示了EANN的大体框架设计:
EANN由于帖子包括文本和图像信息,因此multi-modal feature extractor包括文本和视觉两个特征提取器,然后将它们学习到的特征拼接。fake news detector和event discriminator都连接在multi-modal feature extractor的后面,使用其学习到的特征来作为输入。
- Multi-Modal Feature Extractor
- Textual Feature Extractor
使用Text-CNN作为文本的feature extractor,它利用多个窗口大小不同的过滤器来捕捉不同粒度的特征来提取特征。具体的,文本中的每个word使用word embedding来表示,这些word embedding使用给定数据集的预训练的word embedding来初始化,维度为,第个词的word embedding表示为。一个含有个word的句子就可以表示为:
代表拼接。接着一个大小的卷积核将连续个词的序列作为输入然后输出一个特征,这个卷积的过程可以表示为:
代表ReLU激活函数,代表卷积核权重。经过这一个卷积核卷积过后,这个句子就得到一个特征向量:
然后对这个特征向量做最大池化,输出一个最重要的特征,也就是说一个卷积核最终只会输出一个特征(一个标量)。为了提取不同粒度的特征,我们会采用多种不同大小的卷积核,假设每个不同大小的卷积核使用个,并且有个不同的大小,那么一共有个卷积核,如此Text-CNN对于一个句子提取到的特征向量就是。为了确保文本特征向量和视觉特征向量能够有相同的维度,仍然需要一个全连接层来进行维度转换得到最终提取的特征向量:
这里是全连接层的权重矩阵。
- Visual Feature Extractor
使用VGG19作为视觉特征提取器,在VGG19后面添加一个全连接层来调整维度到,最终得到:
同样是全连接层的权重矩阵。注意这个过程中预训练VGG19的参数是保持不变的,目的是为了防止过拟合。和最终会拼接到一起得到特征表示:
我们使用,这里的是包含文本和图像的帖子的集合。
- Fake News Detector
fake news detector在这里采用一个全连接层softmax分类器,用表示,第个帖子的预测概率分布表示为:
使用代表标签结合,那么fake news detector的交叉熵损失为:
我们需要寻找最优的参数来最小化fake news detector的loss:
这样的fake news detector如果不加限制只能够学习到特定于事件的特征,因此需要 event discriminator来剔除这些特征以捕获具备事件不变性的特征。
- Event Discriminator
event discriminator是一个两层全连接网络,用来将帖子分类到所属的事件,假设一共有个时间。用表示,类似的,其损失表示为:
最小化event discriminator的loss的过程为:
能够用来度量不同事件特征分布的不相似性,这个loss越大说明不同事件的特征分布越相似。为了移除特定于事件的特征,我们寻找一个能够使最大的。这样feature extractor和event discriminator之间就是一个博弈对抗的过程,一方面feature extractor试图愚弄event discriminator,而event discriminator试图寻找特定于事件的特征来进行事件的分类。
- 模型的训练
上述三个部分的最终的loss可以定义为:
是一个平衡因子,在本文中设置。目标是寻找上述的鞍点:
为了达到上述目的,使用梯度反转层以实现以下方式的更新:
学习率按照以下方式进行衰减:
这里,根据训练过程从到变换。
总结来说,整个EANN的训练过程如下:
训练三、实验
在Twitter和Weibo数据集上进行了实验,数据集统计结果如下:
数据集统计对比了多个baseline与EANN的实验结果:
实验
网友评论