当前位置: 首页 > news >正文

什么是GNN?——聚合、更新与循环

在传统的深度学习中,卷积神经网络(CNN)擅长处理网格结构数据(如图像),循环神经网络(RNN)擅长处理序列数据(如文本)。但当数据以的形式存在时(如社交网络、分子结构、推荐系统),我们需要一种全新的架构——图神经网络(Graph Neural Network, GNN)

文章目录

    • 一、GNN核心思想:图上的信息传递
    • 二、GNN三大核心流程
      • 1. 聚合(Aggregate):收集邻居信息
      • 2. 更新(Update):融合自身信息
      • 3. 循环(Loop):多层信息传递
    • 三、 GNN的完整计算流程
    • 四、GNN的应用场景
    • 五、GNN的优势与挑战
    • 六、总结

一、GNN核心思想:图上的信息传递

GNN的核心思想是通过邻居节点的信息聚合来学习节点表示。与传统神经网络不同,GNN考虑了图结构中的拓扑关系,使每个节点的表示都包含其邻居信息。

节点特征
聚合邻居信息
更新节点状态
循环多层
最终节点表示

二、GNN三大核心流程

1. 聚合(Aggregate):收集邻居信息

聚合操作是GNN的第一步,也是最重要的一步。每个节点从其邻居节点收集信息,将这些信息聚合成一个单一向量。

数学表达:

hN(v)(k)=AGGREGATE(k)({hu(k−1),∀u∈N(v)})h_{N(v)}^{(k)} = \text{AGGREGATE}^{(k)}\left(\{h_u^{(k-1)}, \forall u \in N(v)\}\right)hN(v)(k)=AGGREGATE(k)({hu(k1),uN(v)})

其中:

  • N(v)N(v)N(v) 表示节点 vvv 的邻居集合
  • hu(k−1)h_u^{(k-1)}hu(k1) 是邻居节点 uuu 在上一层的表示
  • AGGREGATE\text{AGGREGATE}AGGREGATE 可以是多种函数:均值、最大值、求和等

常用聚合函数:

聚合方式公式特点
均值聚合hN(v)(k)=1N(v)∑u∈N(v)hu(k−1)h_{N(v)}^{(k)} = \frac{1}{ N(v) }\sum_{u\in N(v)}h_u^{(k-1)}hN(v)(k)=N(v)1uN(v)hu(k1)平等对待所有邻居
最大池化hN(v)=max⁡({hu,∀u∈N(v)})h_{N(v)} = \max(\{h_u, \forall u\in N(v)\})hN(v)=max({hu,uN(v)})捕获最显著特征
求和聚合hN(v)=∑u∈N(v)huh_{N(v)} = \sum_{u\in N(v)}h_uhN(v)=uN(v)hu保留邻居信息总量
# 伪代码示例:均值聚合
def aggregate(neighbors):total = sum(neighbor_features for neighbor in neighbors)return total / len(neighbors)

2. 更新(Update):融合自身信息

在聚合邻居信息后,节点需要将邻居信息与自身信息结合,更新自己的状态表示。

数学表达:

hv(k)=UPDATE(k)(hv(k−1),hN(v)(k))h_v^{(k)} = \text{UPDATE}^{(k)}\left(h_v^{(k-1)}, h_{N(v)}^{(k)}\right)hv(k)=UPDATE(k)(hv(k1),hN(v)(k))

其中:

  • hv(k−1)h_v^{(k-1)}hv(k1) 是节点 vvv 上一层的表示
  • hN(v)(k)h_{N(v)}^{(k)}hN(v)(k) 是当前聚合的邻居信息
  • UPDATE\text{UPDATE}UPDATE 通常是一个神经网络(如MLP)或线性变换

更新函数示例:

hv(k)=σ(W(k)⋅CONCAT(hv(k−1),hN(v)(k)))h_v^{(k)} = \sigma\left(W^{(k)} \cdot \text{CONCAT}(h_v^{(k-1)}, h_{N(v)}^{(k)})\right)hv(k)=σ(W(k)CONCAT(hv(k1),hN(v)(k)))

其中:

  • W(k)W^{(k)}W(k) 是可学习的权重矩阵
  • σ\sigmaσ 是非线性激活函数(如ReLU)
  • CONCAT\text{CONCAT}CONCAT 表示向量拼接操作
# 伪代码示例:更新函数
def update(self_feature, aggregated_neighbors):combined = concatenate([self_feature, aggregated_neighbors])return relu(dense_layer(combined))

3. 循环(Loop):多层信息传递

单层GNN只能聚合直接邻居的信息。通过堆叠多层GNN,信息可以在图中传播得更远,捕获更广泛的图结构信息。

数学表达:

H(k)=GNNLayer(k)(H(k−1),A)H^{(k)} = \text{GNNLayer}^{(k)}(H^{(k-1)}, A)H(k)=GNNLayer(k)(H(k1),A)

其中:

  • H(k)H^{(k)}H(k) 是第 kkk 层所有节点的表示矩阵
  • AAA 是图的邻接矩阵
  • 通常 H(0)H^{(0)}H(0) 是节点的初始特征矩阵 XXX

循环过程:

graph LRH0[初始特征 H⁽⁰⁾] --> L1[GNN层1]L1 --> H1[H⁽¹⁾]H1 --> L2[GNN层2]L2 --> H2[H⁽²⁾]H2 --> L3[...]L3 --> HK[H⁽ᴷ⁾ 最终表示]

层数选择:

  • 2-3层通常足够处理大多数任务
  • 层数过多可能导致过度平滑(所有节点表示趋同)
  • 层数过少则无法捕获长距离依赖

三、 GNN的完整计算流程

让我们通过一个具体例子理解三步流程:

聚合
更新
循环
节点A初始特征
收集邻居B,C信息
节点C初始特征
节点B初始特征
节点A新特征
下一层输入

一个完整的K层GNN可以表示为:

hN(v)(k)=∑u∈N(v)hu(k−1)∣N(v)∣(均值聚合)hv(k)=σ(W(k)⋅[hv(k−1)∥hN(v)(k)]+b(k))(更新)hvfinal=hv(K)(经过K层循环)\begin{aligned} h_{N(v)}^{(k)} &= \sum_{u \in N(v)} \frac{h_u^{(k-1)}}{|N(v)|} \quad \text{(均值聚合)} \\ h_v^{(k)} &= \sigma\left(W^{(k)} \cdot [h_v^{(k-1)} \| h_{N(v)}^{(k)}] + b^{(k)}\right) \quad \text{(更新)} \\ h_v^{\text{final}} &= h_v^{(K)} \quad \text{(经过K层循环)} \end{aligned} hN(v)(k)hv(k)hvfinal=uN(v)N(v)hu(k1)(均值聚合)=σ(W(k)[hv(k1)hN(v)(k)]+b(k))(更新)=hv(K)(经过K层循环)

四、GNN的应用场景

  1. 节点分类:预测节点类别(如用户分类)
  2. 链接预测:预测缺失的边(如推荐好友)
  3. 图分类:对整个图进行分类(如分子性质预测)
  4. 聚类:发现图中的社区结构
  5. 生成任务:生成新的图结构(如分子设计)

五、GNN的优势与挑战

优势

  • 显式利用图结构信息
  • 强大的关系推理能力
  • 对不规则数据建模能力强

挑战

  • 过度平滑问题
  • 动态图处理困难
  • 大规模图计算的效率问题

六、总结

GNN通过聚合-更新-循环的三步流程,巧妙地解决了图结构数据的表示学习问题。这种架构让神经网络能够理解复杂的关系网络,在社交分析、生物化学、推荐系统等领域展现出强大潜力。随着研究的深入,GNN正在不断发展出更强大的变体,成为现代AI不可或缺的工具。

输入图数据
聚合邻居信息
更新节点状态
循环多层传播
得到节点表示
下游任务
节点分类
链接预测
图分类
http://www.xdnf.cn/news/1163827.html

相关文章:

  • 注册表清理优化丨Wise RegistryCleaner_v11.1.10.725(官方赠品)
  • USRP采集信号转换为时频图数据集
  • 理解向量及其运算-AI云计算数值分析和代码验证
  • Mac上安装Homebrew的详细步骤
  • CCLink IE转ModbusTCP网关与三菱PLC通讯无纸记录器
  • selenium爬取图书信息
  • 旋转目标检测(Rotated Object Detection)技术概述
  • Selenium 处理表单、弹窗与文件上传:从基础到实战
  • ACE 插入元件
  • cs336 Lecture2
  • 使用Langchain调用模型上下文协议 (MCP)服务
  • AI革命带来的便利
  • Go语言进阶书籍:Go语言高级编程(第2版)
  • 14.7 Alpaca格式深度解析:3倍指令准确率提升的LLM微调秘诀
  • Jenkins 不同节点间文件传递:跨 Job 与 同 Job 的实现方法
  • Linux | C Shell 与 Bash 的差异 / 环境变量配置问题解析
  • 了解 ReAct 框架:语言模型中推理与行动的协同
  • vscode 使用说明二
  • vscode创建vue项目报错
  • 5.6 framebuffer驱动
  • 人工智能之数学基础:事件间的关系
  • MySQL 核心知识点梳理(3)
  • Qualcomm Linux 蓝牙指南学习--验证 Fluoride 协议栈的功能(2)
  • Java学习----NIO模型
  • 爬虫实战指南:从定位数据到解析请求的全流程解析
  • PyTorch 实现 CIFAR-10 图像分类:从数据预处理到模型训练与评估
  • 【PHP安全】免费解密支持:zend52、zend53、zend54好工具
  • C# 结构体
  • AI Agent与MCP协议构建标准技术报告(2025Q3)
  • 【科研绘图系列】R语言绘制棒棒图和哑铃图