Neo-GNNs: Neighborhood overlap-aware graph neural networks for link prediction. NeurIPS, 2021.
概
一种计算上相对高效的, 同时利用结构信息和特征信息的链接预测模型.
符号说明
- G=(V,E), graph;
- V={v1,v2,…,vN}, N nodes;
- E={eij|vi,vj∈V}, edges;
- A∈RN×N, adjacency matrix;
- D∈RN×N, diagonal matrix Dii=∑jAij;
- X∈RN×F, node features
Motivation
-
link prediction 有很多启发式的方法, 比如利用
SCN(u,v)=|N(u)∩N(v)|=∑k∈N(u)∩N(v)1,SRA(u,v)=∑k∈N(u)∩N(v)1dk,SAA(u,v)=∑k∈N(u)∩N(v)1logdk.
-
作者的做法是将它一般化, 即
S(u,v)=∑k∈N(u)∩N(v)xk.
Neo-GNN

-
xk 是这般设计的:
xstructi=Fθ(Ai)=fθnode(∑j∈Nifθedge(Aij)),
通过可学习的参数从邻接矩阵 A 中获得有用的结构信息.
-
有更一般的计算方式. 我们令
Xstruct=diag(xstruct)∈RN×N,
则当 fθedge(x)=x 而 fθedge(x)=1/√logx 的时候,
S(u,v)=zTuzv,Z=AXstruct.
-
更为一般的, 为了利用更高阶的信息, 作者实际上采用如下的形式:
Z=gΦ(L∑l=1βl−1AlXstruct),
其中 β 是用来控制高阶信息的一个超参数.
-
除此之外, 通过一个普通的 GNN 得到传统的 (smoothed) 节点特征:
H=GNN(X,~AGNN;W)∈RN×d′.
-
最后两个结点存在边的概率通过如下的方式得到:
^yij=α⋅σ(zTizj)+(1−α)⋅σ(s(hi,hj)),
其中 α 是可训练的参数.
-
训练的时候, 两个分支也要单独参与训练:
L=∑(i,j)∈D(λ1BCE(^yij,yij))+λ2BCE(σ(zTizj),yij)+λ3BCE(σ(s(hi,hj)),yij).
代码
[official]
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2022-08-25 ItemRank: A Random-Walk Based Scoring Algorithm for Recommender Engines