∂H∂F−c)怎么判断一个映射是不是压缩映射? - 知乎
网络结构
通过以上描述,我们可以将一个简单的图神经网络的过程用下图表示。
注:因为历史和习惯等原因,原始论文 《The graph neural network model》
所用的符号与本文有所不同。
上图中的li 代表的是节点i 的 label
,其实也就是我们今天所说的节点特征向量xi,边特征向量同理.
参数学习过程
整个参数的学习主要分为两个部分,前向传播和后向传播。
前向传播
输入:给定隐状态迭代停止条件ϵf、当前参数W 和确定的图G;
输出:不动点H
传播过程大致总结如下:
- 初始化各个隐状态hi(0)
- 循环迭代,根据转移函数F 更新隐藏状态H(t+1)=σ(AH(t)+b) ,激活函数σ(⋅)
- 计算是否满足停止条件:∣∣H(t+1)−H(t)∣∣≤ϵf
- 迭代步t 自增
- 循环结束得到表示H.
实际上编码网络(网络结构图的中间部分)仅仅类似于静态的前馈神经网络,但是对H 的迭代过程相当于不断经过一层又一层神经网络,因为结束条件是隐状态的稳定,所以这个层数是动态确定的,并且网络权重根据输入图的拓扑结构来共享。所以为静态网络设计的二阶学习算法、剪枝算法、以及逐层学习算法无法直接应用于 GNN
。
后向传播
模型中需要学习的参数是将各特征进行reshape
的神经网络映射ϕ,具有参数W。
于是通过链式法则从迭代步t=T→0 逐步往前追溯(相当于从最后一层网络往前传播,但是权重是共享的),用于计算∂W∂J,然后通过梯度下降法更新权重。
该过程由于使用了梯度下降法,所以也需要一个收敛的结束条件(注意与隐状态结束条件不同!)
基础GNN的不足
实验结果表明GNN对于结构化数据的建模十分有效,但仍然存在着诸多的不足:
- 对于不动点隐藏状态H 的更新十分低效;
- GNN在迭代的过程中用共享参数W,然而大多标准网络在不同的网络层数使用不同的参数;
- 在原始的GNN中难以有效建模的带边标签的特征。例如,在知识图谱中边代表着节点间的关系类型,不同边的消息传递应该根据他们的类型有所不同。怎么样去学习边的隐藏状态也是—个重要的问题;
频域图卷积网络
卷积神经网络的出色表现让我们“急不可耐”地想将其推广到图神经网络中,我们希望它在图里能够改善基础GNN的不足。
而卷积这一概念,追根溯源就和《信号分析与处理》脱不了干系了。事实上谈到卷积我们应该有共识,那就是在频域上的卷积和时域上的卷积(图像处理领域我们把后者称作空域,图论中也是类似的说法)。卷积的进一步联系是傅里叶变换,它为我们提供了不同频率的正弦波和余弦波的特定基 (DFT 矩阵,例如 Python 中的 scip.linalg.dft
),这样我们就可以将信号或是图像表示为这些波的总和。
所以,显而易见地,对于图卷积同样也分了两个域来研究:频域和空域。很多时候,图的频域我们也叫图的谱域(图谱)。
在图论中,“频谱” 意味着拉普拉斯矩阵L 的特征分解。可以认为拉普拉斯矩阵L 是一种特殊的邻接矩阵,而特征分解就是为了找到构成我们的图基本正交分量的一种方法。
关于拉普拉斯矩阵和图傅里叶变换的内容,本站其他文章做了更详细的介绍和推导,本文默认读者已经了解。
切比雪夫最佳逼近
图卷积在谱域上的定义由下式给出。而f,U,Λ 均由我们给出的图G 唯一确定。所以对于深度学习任务,我们需要学习的是参与卷积的g。
f∗g=Ugθ(Λ)UTf
得益于图谱卷积相当于是做矩阵乘法,所以计算机只需学习对角矩阵gθ(Λ) 即可(Λ是拉普拉斯矩阵做特征分解得到的特征值对角矩阵)。
显然,当图节点数量n 足够大时,计算机对图卷积的计算代价将会很大程度地增加,所以必须进一步考虑计算优化的问题。
在论文《Wavelets on Graphs via Spectral Graph Theory》中,作者给出的方法是利用切比雪夫最佳逼近多项式。
相关知识可参阅:初识切比雪夫多项式 - 知乎
任意一个连续函数 f(x),x∈[−1,1] 都可以被展开为切比雪夫多项式级数:
f(x)where A0An=n=0∑∞AnTn(x)=π1∫−111−x2f(x)dx=π2∫−111−x2f(x)Tn(x)dx
其中,Tn(x) 为n 次切比雪夫多项式,其递推式为:
T0(x)=1,T1(x)=x,Tn+1(x)=2xTn(x)−Tn−1(x)
我们的目标就是将切比雪夫多项式级数的前K 项近似替代gθ(Λ)。为此,我们需要对特征值(函数gθ 的自变量)进行拉伸或收缩,使得λi∈[−1,1].
方法也非常简单:
Λ~=λmax2Λ−I
从而我们有:
gθ(Λ)≈k=0∑Kθk′Tk(Λ~)
其中θ′∈RK+1 为切比雪夫系数。
接下来再带入到卷积公式:
f∗g≈U(k=0∑Kθk′Tk(Λ~))UTf=k=0∑Kθk′UTk(Λ~)UTf=k=0∑Kθk′Tk(UΛ~UT)f=k=0∑Kθk′Tk(L~)f//∵L=UΛUT
其中,我们的L~ 需要λmax 作为前置知识,但是根据拉普拉斯矩阵的对称归一化Lsym 的基本性质,其瑞利商最大值为2(也就是说 \lambda_\max=2),因此我们只需对L 进行归一化之后,得到:
\tilde{L}=\frac2{\lambda_\max}L-I=L-I最终,计算机实际上只需要学习的是系数θk′,k=0,1,...,K。
可见,最终的近似表达式不再需要U,Λ 的参与了,换句话说就是无需再对拉普拉斯矩阵做特征值分解了。而特征值分解正是计算代价巨大的原因。
其次,因为切比雪夫多项式的递归性质,在计算上每次只需要根据前两次的结果做乘法和减法,就可以得到当前结果。
SpectralNet
Spectral Convolutional Neural Network (SCNN) 谱卷积神经网络 是由 Joan Bruna 等人于2014年提出的(Spectral networks and locally connected networks on graphs)。
类似于卷积神经网络,SCNN 在归一化的拉普拉斯矩阵谱域上定义图卷积操作,其中待学习的参数就是每一层的卷积核Θ:=gθ(Λ)。
具体来说,第k 层网络的第j 个通道,其所有节点的输出特征堆叠H:,j(k) 就可以表示为:
H:,j(k)=σ(i=1∑ck−1UΘi,jUTH:,i(k−1))
即k−1 层的ck−1 个通道都与对应的卷积核进行卷积,最后相加起来并经过激活函数。
显然 Spectral CNN 面临三个问题:
- 对图的任何扰动都会导致特征基的变化;
- 学习到的卷积核是邻域相关的,因此不能应用于具有不同结构的图;
- 特征分解需要 O(n3) 的计算复杂度(Spectral CNN 并没有做近似处理)
ChebNet
Chebyshev Spectral CNN (ChebNet) 切比雪夫卷积神经网络 由 Michael Defferrard 等人在2016年提出。正如它的名字一样,ChebNet 利用了切比雪夫多项式的最佳逼近多项式方法,简化了卷积的计算。
其中,
- 卷积核只有 K+1 个可学习的参数,大大降低了参数的复杂度
- ChebNet 不需要对拉普拉斯矩阵做特征分解了,这是区别于SCNN的非常明显的一点,它省略了最耗时的步骤
- ChebNet 的卷积核具有空间局部性,K 正好是卷积核的“感受野半径”,即将中心顶点的K 阶邻点作为邻域节点
GCN | GraphConvNet
Graph Convolutional Network (GCN) 图卷积网络 在2017年由 Thomas Kipf 和 Max Welling 提出。他们在 ChebNet 的基础上限制K=1,并取 \lambda_\max=2(正如我们之前推导的那样),这缓解了节点度分布范围较大时产生的局部结构过拟合问题。
不难得出卷积操作被简化如下:
f∗g≈θ0′f+θ1′L~f
为了限制参数的数量并避免过拟合,GCN 进一步假设θ=θ0′=−θ1′.
代入L~=Lsym−I=−D−1/2WD−1/2,最终可得:
f∗g≈θ(I+D−21WD21)f
值得注意的是,叠加很多个卷积层的时候,可能会出现数值不稳定以及梯度爆炸/消失的情况,所以论文中引入了一个重归一化的技巧 (renormalization):
Alet A~[D~]iif∗g:=W//论文中将A记为邻接矩阵(可带权)=A+I=j=1∑nAij:=θ(D~−21A~D~21)f
最终,具有C 个通道的图,每个节点的特征堆叠得到的输入信号X∈Rn×C 经过F 个(输出通道数)卷积核之后得到的输出信号Z∈Rn×F 如下:
Z=σ(D~−21A~D~21XΘ)
这里说的通道数C,F 其实也可以理解为输入特征的维度和输出特征的维度。通道数是沿用图像卷积的说法。
值得注意的是,如果我们再把D~−21A~D~21 记作A^ ,将其视为一种归一化后的邻接矩阵。那么 GCN 输出信号的A^XΘ 就可以看作通过邻接矩阵对每个节点的邻点做某种加权平均。这与空间域图卷积的思想一致。所以 GCN 除了频域上的卷积解释外,也有空域中的解释。
AGCN | 自适应图卷积
上述模型均使用原始的图结构来表示节点之间的关系。然而不同节点之间也可能存在隐式关系。简单来说就是,可能邻居节点的相似性比非邻居节点还要更低,这是因为在一定情况下固定的图的结构的并不代表节点相邻特征相似。
于是 Adaptive Graph Convolutional Network (AGCN) 自适应图卷积网络 被提了出来,它通过学习“残差”拉普拉斯矩阵Lres 与原来的L 结合来学习这种隐式关系,模型/论文中的 SGC-LL Layer 就是在做这个事。
因为拉普拉斯矩阵代表了图的拓扑结构,而如果将节点间新的关系添加进去将会得到包含隐性相关性的新拓扑。作者利用广义的马氏距离(mahalanobis distance)计算节点间的距离:
D(xi,xj)=(xi−xj)TM(xi−xj)
狭义的马氏距离中,M 为数据的协方差矩阵;此外,当它是单位阵时,就变成了欧氏距离
在 AGCN 模型中 M 是对称的半正定矩阵,保证 M=WdWdT 且 Wd∈Rd×d 是用于学习的权重参数,d 为节点特征维度。基于马氏距离得到高斯核计算公式如下:
Gxi,xj=exp(−D(xi,xj)/(2σ2))
对其进行标准化后得到密集的邻接矩阵 A^,残差矩阵就为Lres=I−D^−1/2A^D^−1/2,其中的D^ 也是由A^ 中的度得来的。
于是,新的拉普拉斯矩阵就被定义为L^=L+αLres,α 为可调超参数。
DGCN | 对偶图卷积
Dual Graph Convolutional Network (DGCN) 对偶图卷积网络 同时考虑了图的局部一致性和全局一致性——利用两个共享权重的卷积网络进行捕捉。该工作还采用了无监督损失函数在最后对二者进行聚合。
Note: 对偶翻译自 dual
,代表论文中提到的两个卷积网络。而有些情况,谈到 对偶图 则指的是“将边转换为顶点、将顶点转换为边”的新图G′ 与原来的图G 之间是对偶关系。
- 用于捕捉局部一致性的卷积网络ConvA 与 GCN 模型一致;
- 用于捕捉全局一致性的卷积网络ConvP 利用正点互信息矩阵 PPMI 代替邻接矩阵。
H’=σ(Dp−21XpDp−21HΘ)
其中,Xp 为PPMI矩阵,Dp 是Xp 的对角度矩阵。
空域图卷积网络
与图像中的卷积神经网络类似,基于空间的图卷积将中心节点的表示与其相邻节点的表示进行卷积,以得出中心节点的更新表示。具体可参考下图。
从另一个角度来看,基于空间的 ConvGNN 其实是和我们最早提出的 基础GNN 中,共享信息传播/消息传递的思想,是一样的。其实空间图卷积操作本质上就是沿边传播节点信息。
MPNN | 消息传递网络
Message Passing Neural Network (MPNN) 消息传递神经网络 是由 Google 科学家提出的一种图监督学习模型。这个模型比之后将要介绍的模型提出得更晚,但是因为其概括性好的,换句话说已经成为一种空域卷积的形式化框架和一般范式的存在了。为了方便理解我们先讲解它。
MPNN 将空域卷积分解为两个过程:消息传递与状态更新操作。分别由函数M(⋅),U(⋅) 完成。MPNN在卷积层结束之后,还提出可以针对所有节点的信息,利用读出函数R(⋅) 计算整个图的特征向量。
消息传递阶段:节点v 在第l+1 层的隐状态可以用下面这个表达式得出:
hv(l+1)=Ul+1hv,u∈N(v)∑Ml+1(hu(l),hv(l),x(v,u))
读出阶段:根据整个图的特征(Graph Feature),将其映射为一个描述全图特征的特征向量(Eigenvector):
y^=R({hv(K)∣v∈G})
其中,K 为最终卷积层的层数。
MPNN看起来与基础的GNN模型十分相似,但是它并不是基于巴拿赫不动点定理来更新状态的。我们选取的层数K 决定了聚合多少步长的邻点的信息。这就是图卷积网络中常提到的K-hop 。一个简单的K-hop 即图卷积过程如下图所示:
简单起见,我们仅仅看K=2 时的信息传递过程,并且为了方便展示,只聚焦于单个目标节点的更新。
设目标节点为A,与之相邻的节点就是B,C,D。那么,它们的信息聚合给A 将是最后一层所做的事。同理,与A 的距离是 2 的那些节点会在倒数第二层聚合到B,C,D 中,以此类推。
当我们选取不同的函数来进行信息传递、状态更新和全局信息读出时,就可以演化出不同的空域卷积的图神经网络。
Neural FP
2015年,David Duvenaud 等人在论文《Convolutional Networks on Graphs for Learning Molecular Fingerprints》中提出了针对具有不同度的节点使用不同的权重矩阵,并以此得到了模型 Neural FP。
该模型十分简洁,通过聚合节点v 的邻点表示,并且和自身的嵌入表示相加,然后由权重矩阵进行转换就能得到本层的嵌入表示输出。
hv(k)=σ(xWk∣N(v)∣)
其中,x=hv(k−1)+∑u∈N(v)hu(k−1),Wt 表示节点度为t 时所使用的权重矩阵。
事实上这个模型就是将MPNN的信息传递函数设置为去除了偏置的仿射变换,增加了权重矩阵的类型。
然而,因为 Neural FP 存在处理大规模图导致参数量过大的情况,所以并不能很好地适用于其他任务。
PATCHY-SAN
此前我们的学习都是想办法基于图结构这种非欧式结构的数据进行神经网络的衍生。而2016年的《Learning Convolutional Neural Networks for Graphs》则另辟蹊径:通过将图结构抽离并表示出来,然后在经典的CNN模型上训练。
原论文的地址:https://arxiv.org/pdf/1605.05273v2.pdf;
官方PPT讲解:https://www.matlog.net/icml2016_slides.pdf
这项工作主要分为四个步骤:
- 选择w 个节点序列;
- 从所选择的每个节点中根据图结构衍生出包含该节点的连通子图,节点数为k,k也是感受野;
- 图归一化:为w 个子图映射出序号,序号从1→k;
- 提取特征:将子图节点的节点特征与边特征作为传统CNN的通道建立新的欧式空间数据;
最后,将提取出来的数据输入到传统CNN模型中进行训练。
NN4G
Neural Network for Graphs (NN4G)是第一个提出的基于空间的ConvGNNs。
NN4G通过直接累加节点的邻域信息来实现图的卷积,此外它还吸收了残差网络的跳接来记忆每一层的信息(累加此前每一层的特征)。
H(k)=σ(XW(k)+i=1∑kAH(i−1)Θ(i))
不难发现,NN4G的主体部分——AHΘ 是和 GCN 一样的,只是A 并不是用了经过归一化的A~,这可能会导致隐藏节点状态具有极其不同的尺度。
DCNN | 扩散卷积
Diffusion Convolutional Neural Network (DCNN) 扩散卷积神经网络 将图卷积视为扩散过程。它假设信息以一定的转移概率从一个节点转移到其相邻节点之一,使得信息分布在几轮后达到平衡。
事实上,这个过程与马尔科夫链的随机游走过程一致。所以可以自然而然地得出第k 层(也就是传播/扩散到了步长为k 的顶点)时,各个顶点的隐藏表示矩阵:
H(k)=σ(W(k)⊙PkX)
其中,概率转移矩阵由P=D−1A 计算得出。
DCNN 将每一层的隐藏表示矩阵全部连接在一起作为最终的输出。使用概率转移矩阵的幂意味着遥远的邻居向中心节点贡献的信息非常少。
其他技术细节
数据集划分
图神经网络的训练和其他结构的网络一样,可以分为基于有监督的标签训练及无监督的训练。但其中,特别是针对有监督学习而言,最让新手产生疑惑的点就是,这种图结构的输入数据集应该怎么划分成对应的训练集、验证集和测试集。
事实上这个问题如图所示,更进一步地分化出了两种学习任务或设置:
- Inductive Setting(归纳式学习):数据集本身构成了一个完整的图,训练阶段将此图分离出多个子图,从一系列子图里按比例划分训练集、验证集和测试集。通常训练阶段只是在子图上进行,而在测试阶段则需要用学习到的网络来预测训练时完全没接触过的未知点(unseen node)。如果数据集是一系列图的集合(或动态图),则是以一张张图为单位进行数据划分。由于这个特性,归纳式学习是可以迁移的。即在这个图上训练好的模型,可以迁移到另外一个图中使用,与传统的其他深度学习任务相同。
- Transductive Setting(直推式学习):数据集本身构成了一个完整的图,但是训练时用到了整张图的结构信息,只对按比例划分出来的节点或边 提供 ground truth 用作训练,其余的节点或边的标签在训练时不可见,只在训练好后用作验证或测试。显然由于这个特性,这类学习方法不适用于 graph-level 任务。BTW,这种学习某种程度上也是半监督学习(semi-supervised learning)。
GCNs论文的作者采用的就是 Transductive Learning,而接下来我们将介绍的 GraphSAGE 论文则是一种 Inductive Learning 方法。
采样与聚合 | GraphSAGE
由于实际工程中节点的邻居数量可能从一到一千甚至更多不等,因此获取节点邻居的全部大小是低效的。
2017年由 William Hamilton 等人提出的 GraphSAGE 作为一个通用的归纳推理模型(Inductive learning),利用了采样方法为每个节点获取固定数量的邻居,然后再通过聚合得到所有邻居节点的单一表示。整体流程如下:
具体来说,GraphSAGE中的过程主要分为以下两点:
- 在图中随机采样若干个节点(要更新的目标节点集合),节点数为传统任务中的
batch_size
。对于每个节点,随机选择固定数目的邻居节点 (这里邻居不一定是一阶邻居,也可以是二阶邻居) 构成用于卷积操作的子图。 - 将邻居节点的信息通过Aggregator 函数聚合起来,然后更新刚才采样的目标节点。
最终得出,GraphSAGE的状态更新公式如下:
hv(l+1)=σ(W(l+1)⋅Aggregator(hv(l),{hu(l)∣∀u∈N(v)}))
事实上,GraphSAGE最核心的贡献就是提出了采样的思想。而这里的聚合与MPNN范式以及GCN的"信息传递与更新"的思想是类似的。不过,GraphSAGE也给出了不同的聚合器方法以供参考:
- Mean Aggregator:直接取邻居节点的平均
- GCN Aggregator:将邻居节点与目标节点算在一起共同进行平均(物理意义正好和GCN相同,因而这样取名)
- LSTM Aggregator:使用LSTM来 encode 邻居的特征。 这里忽略掉邻居之间的顺序,即随机打乱,作者的想法是LSTM的表示能力比较强。但因为LSTM是处理序列数据的,因此不同打乱顺序会得出不同的结果
- Pooling Aggregator:把各个邻居节点单独经过一个MLP得到一个向量,最后把所有邻居的向量做一个element-wise 的 max-pooling或者其他的pooling。公式如下:
Aggregatorkpool=u∈N(v)maxσ(Wpoolhu(k)+b)
一个利用池化聚合器编码邻居节点的嵌入表示/特征/隐状态,并且使用拼接的方式结合样本目标节点的特征和邻居节点的特征,最终用于有监督学习的 GraphSAGE 流程可以用下图进行直观地展示:
图片摘自:《Graph-based representation for identifying individual travel activities with spatiotemporal trajectories and POI data》
层级池化
待更:图粗化、可微池化
图注意力网络(GAT)
GCN的局限性
- 无法完成 归纳(inductive)任务,也即处理动态图问题;
- 处理有向图的瓶颈,不容易实现分配不同的学习权重给不同的 neighbor;
- 对于一个图结构训练好的模型,不能运用于另一个图结构(所以此文称自己为半监督的方法);
为了解决以上问题,已经在序列任务中表现出强大能力的注意力机制被提出用于 GCNs 的“传递邻居消息”的过程中。所以,图注意力网络(Graph Attention Networks,GAT) 其实是图卷积网络家族的一种方法。
如果你尚不了解注意力机制,那么本站也有对注意力机制的相关介绍:
图注意力层
对于含有N 个节点的图,我们一共会构造N 个图注意力网络,因为每一个节点都需要对于其邻域节点训练相应的注意力。而图注意力网络的层数K ,也就是选择使用多头注意力机制,则根据需要决定。
我们在这里先分析K=1,即一个单层图注意力网络的工作原理。我们给出两个相邻节点i,j 的评分函数eij 和权重系数αij 的计算方法:
eijαij=LeakyReLU(a⊤[Whi∣∣Whj])=softmax(eij)=∑k∈N(i)exp(eik)exp(eij)
式中,我们先对两个节点特征进行仿射变换,然后拼接在一起,再和权重向量a 作内积,通过非线性激活函数LeakyReLU 得到评分函数,利用softmax 进行归一化得到权重系数。整个过程可以用下图描述:
最终,我们得到节点i 的嵌入表示更新公式为:
hi′=σj∈N(i)∑αijWhj
当K>1 时,即采用了多头注意力机制之后,多头得到的嵌入表示可以利用拼接或求平均值的方式得到。下图展示的是节点 1
在K=3 层的图注意力网络下,得到的更新嵌入。
GAT如何解决问题
针对前面提出的 GCNs 的问题,GAT是如何攻破的呢?这里做出简要的说明。
- GAT因为只学习注意力机制的线性变换权重,而并不依靠训练集的图的结构。所以图中再次产生新的结点时,只要知道边连关系就能直接前向传播计算出结果。
- GAT只依靠边连关系,对有向图来说很友好,而GCN因为拉普拉斯矩阵的对称性,所以不能直接处理有向图;
- 同(1),就算给出新的图,只要知道边连关系(且保证特征维度与训练集相同)就能直接前向传播计算结果。
循环图神经网络
图神经网络的另一种趋势是在前向传播过程中使用 GRU 或 LSTM 等 RNN 门控机制,以弥补基础 GNN 模型的不足,并且能够提高长距离信息传播的有效性。
本站循环神经网络总结性文章:
Note:因为循环图神经网络流派是为了弥补基础GNN模型而分支下去的,与前述我们大量探讨的图卷积网络不同,循环图网络还在想办法解决基于巴拿赫不动点定理而产生的设定停止参数、迭代更新问题。
GGNN | 门控图网络
2016年 门控图神经网络(Gated Graph Neural Network, GGNN) 被 Yujia Li 等人提出。GGNN 将隐状态的迭代看作是一个长度为T 的序列输入的隐状态更新过程。从而利用 RNN 中的门控循环单元来进行更新。
GGNN 的更新公式如下:
hv(t+1)=GRUhv(t),u∈N(v)∑Wedgehu(t)
具体来说,把第t 次迭代得到的隐状态(目标节点v 的嵌入表示)hv(t) 看作是GRU中在时间步t 时的输入,把v 所有相邻节点的嵌入表示进行加权求和,以作为GRU中“过去所有数据的隐状态”。
Graph-LSTM
2017年,吸收了基于树结构的LSTM模型:Child-Sum Tree-LSTM、N-ary Tree-LSTM,Nanyun Peng 等人进一步提出了 Graph-LSTM,为不同的边标签使用不同的可学习的遗忘门权重、输出门权重和输入门权重。
其他图网络
图残差网络
图自编码器
参考
- 刘知远,周界著 李泺秋译. 《图神经网络导论》. ISBN : 978-7-115-55984-5
- 【泛函基础 1.4】Banach 不动点定理 - 知乎
- 怎么判断一个映射是不是压缩映射? - 知乎
- 小白数学分析|1. 什么是收敛列、柯西列、完备空间 (convergent sequence, Cauchy sequence, complete metric space)? - 知乎
- 图神经网络 - 一、GNN - 《AI算法工程师手册》 - 书栈网 · BookStack
- 初识切比雪夫多项式 - 知乎
- 理解图傅里叶变换,图卷积,基于频域的图卷积神经网络 (GCN) - 知乎
- AGCN:自适应图大小的图卷积网络模型 - 知乎
- 论文笔记:Learning Convolutional Neural Networks for Graphs - 知乎
- 图神经网络(Graph Neural Networks,GNN)综述 - 知乎
- 从图(Graph)到图卷积(Graph Convolution):漫谈图神经网络模型 (二) - SivilTaram - 博客园
- Graph Attention Network (GAT) 图注意力网络 论文详解 ICLR2018 - 曹明 - 博客园
- GNN dataset 划分 - kalice - 博客园
- 【CS224W学习笔记 day07】 GNN划分训练集、验证集、测试集、任务定义 - 知乎