DKN: Deep Knowledge-Aware Network for News Recommendation
DKN: Deep Knowledge-Aware Network for News Recommendation[1]
目录
ABSTRACT
在线新闻推荐系统致力于在庞大的新闻数据中为用户提供个性化的新闻推荐。一般情况下,新闻语言高度浓缩并且主要由知识实体构成。已有的推荐方法没有进行外部知识的抽象与学习,不能够充分的发掘新闻在知识层面的联系。本文结合知识图谱提出了基于深度知识感知网络(DKN)的新闻推荐系统。DKN在基于内容的深度推荐框架下进行点击率预测。该网络的核心是一种多通道、词-实体校准(word-entity-aligned)的知识感知卷积神经网络(KCNN),融合了新闻的语义层和知识层表示。同时引入attention机制处理用户兴趣的多样性,动态的根据当前候选新闻整合用户历史新闻记录。
KEYWORDS:News recommendation; knowledge graph representation; deep neural networks; attention model
1. INTRODUCTION
新闻推荐系统很难拥有显著的效果,主要受到三个方面的问题限制。
新闻有很强的时效性并且新闻间的相关性在很短时间内失效。
用户对话题比较敏感,同时有特定的几个种类。根据多元化阅读历史动态的衡量用户的兴趣是新闻推荐系统的关键
新闻语言高度浓缩并且主要由知识实体构成。如图1,通过知识实体可以将两条新闻进行连接,反映出新闻在知识层面的关联性。
为了解决上述问题,在知识图谱方法的启发下,提出了DKN。
DKN在基于内容的深度推荐框架下进行点击率预测,每次将一条候选新闻和一个用户的点击历史作为输入,输出该用户点击此新闻的概率。对于一条输入的新闻,首先将文本中每个单词与知识图谱中的实体建立一一对应,并搜索相邻接的实体进而对新闻包含的信息进行了扩充。然后通过KCNN融合新闻的语义层和知识层的表示。同时引入attention机制处理用户兴趣的多样性,动态的根据当前候选新闻整合用户历史新闻记录,学习得到用户不同时期点击的权重。最后通过用户和候选新闻的embedding,采用深度神经网络进行点击率预测。
2. PRELIMINARIES
知识图谱embedding,基于卷积神经网络的句子重表示学习。
2.1 Knowledge Graph Embedding
典型的知识图谱包含数以百万计的实体-关系-实体三元组 (h,r,t) ( h , r , t ) 。给定知识图谱中所有的三元组,知识图谱embedding的目标是学习每一个实体和关系的低维重表示向量,该表示需要保留原有知识图谱的结构信息。Translation-based知识图谱embedding方法主要有以下四种:
TransE 引入超平面 wr w r ,目标函数:
fr(h,t)=∥h+r−t∥22 f r ( h , t ) = ‖ h + r − t ‖ 2 2TransH 目标函数:
其中 h⊥=h−ω⊤rhwr,t⊥=t−ω⊤rtwr h ⊥ = h − ω r ⊤ h w r , t ⊥ = t − ω r ⊤ t w r ,且 ∥wr∥2=1 ‖ w r ‖ 2 = 1
- TransR 引入投影矩阵 Mr M r 目标函数:
其中 hr=hMr,tr=tMr h r = h M r , t r = t M r
- TransD 引入投影向量 rp,hp,tp r p , h p , t p 代替投影矩阵 Mr M r ,目标函数:
其中 h⊥=(rph⊤p+I)h,t⊥=(rpt⊤p+I)t h ⊥ = ( r p h p ⊤ + I ) h , t ⊥ = ( r p t p ⊤ + I ) t
训练损失函数:
其中 Δ,Δ′ Δ , Δ ′ 表示正负实例, γ γ 表示两种实例的阈值
2.2 CNN for Sentence Representation Learning
Kim CNN架构如图2:
ω1:n
ω
1
:
n
表示长度为n的句子。
w1:n=[w1w2⋯wn]∈Rd×n
w
1
:
n
=
[
w
1
w
2
⋯
w
n
]
∈
R
d
×
n
表示句子的词嵌入矩阵。
wi∈Rd×1
w
i
∈
R
d
×
1
是第
i
i
个单词的嵌入。是filter,
l
l
是窗口大小。
池化:
3. PROBLEM FORMULATION
新闻推荐系统的公式化表述。用户
i
i
,点击历史记录,
tij
t
j
i
表示被用户
i
i
点击的第条新闻的标题。
每个标题
t
t
转化为一个单词序列,即。每个单词
ω
ω
在知识图谱中可能会有一个实体
e
e
与之对应。
给定用户历史点击,将新闻标题中的单词和知识图谱中的实体进行对应,进一步预测用户点击一个候选新闻
tj
t
j
的概率。
4. DEEP KNOWLEDGE-AWARE NETWORK
DKN详细介绍:整体框架,知识提取,KCNN设计,attention机制。
4.1 DKN Framework
整体框架如图3示。候选新闻和用户点击的新闻作为输入。每条新闻都通过一个KCNN对其标题进行处理,产生相应的嵌入向量。引入attention机制获得最终的用户embedding。最后采用深度神经网络得到点击概率预测。
4.2 Knowledge Distillation
1、从新闻内容中通过预先定义的知识图谱提取知识实体;
2、根据提取的知识实体构建知识图谱子图,包含新闻中提取的实体和相邻的实体。
3、根据提取的知识图谱子图,通过成熟的embedding方法进行实体重表示学习。
知识萃取过程如图4示:
通过embedding方法得到的单点表示在实现中限制了推荐能力。这里拓展原有的方法添加实体的上下文关系进行embedding处理。实体
e
e
的上下文语境定义为它在知识图谱中相邻节点构成的集合:
由于上下文语境实体和当前实体在语义和逻辑上有着紧密的联系,所以上下文语境的使用能够提高实体的可分辨能力。图5阐明了使用实例。通过计算上下文语境实体的平均得到上下文语境embedding:
4.3 Knowledge-aware CNN
t=w1:n=[w1,w2,⋯,wn]
t
=
w
1
:
n
=
[
w
1
,
w
2
,
⋯
,
w
n
]
表示长度为n的新闻标题t的行输入序列,
w1:n
w
1
:
n
表示标题的词嵌入矩阵,既可以是通过大规模语料库预先学习得到也可以随机初始化。为了将前面从知识图谱中学到的实体的embedding引入到网络中去,需要对实体嵌入进行转化映射到词向量空间中去。
线性转换映射:
非线性转换映射:
最终得到多通道输入矩阵:
通过卷积神经网络,经过卷积层和池化层进行学习,最终得到输入新闻标题 t t 的重表示:
4.4 Attention-based User Interest Extraction
给定用户的点击历史 {ti1,ti2,⋯,tiNi} { t 1 i , t 2 i , ⋯ , t N i i } ,被点击的新闻embeddings可以表示为 {e(ti1),e(ti2),⋯,e(tiNi)} { e ( t 1 i ) , e ( t 2 i ) , ⋯ , e ( t N i i ) } 。用户i当前候选新闻 tj t j ,可以简单表示为:
为了区分用户点击历史中不同新闻对当前新闻的影响,引入attention机制,网络结构如图3示。通过softmax函数得到归一化的权重。
用户
i
i
的embedding:
通过另一个深度神经网络得到用户 i i 点击新闻的概率:
5 EXPERIMENTS
Baselines: LibFM,KPCNN,DSSM,DeepWide,DeepFM,YouTubeNet,DMF
[1]: Wang H, Zhang F, Xie X, et al. DKN: Deep Knowledge-Aware Network for News Recommendation[J]. arXiv preprint arXiv:1801.08284, 2018.