图神经网络(GNN)的基本原理

前言

本文结合一个具体的无向图来对最简单的一种gnn进行推导。本文第一部分是数据介绍,第二部分为推导过程中需要用的变量的定义,第三部分是gnn的具体推导过程,最后一部分为自己对gnn的一些看法与总结。

1. 数据

利用networkx简单生成一个无向图:

代码语言:javascript代码运行次数:0运行复制

# -*- coding: utf-8 -*-"""@Time :2021/12/21 11:23@Author :KI @File :gnn_basic.py@Motto:Hungry And Humble"""import networkx as nximport numpy as npimport matplotlib.pyplot as pltimport pandas as pdG = nx.Graph()node_features = [[2, 3], [4, 7], [3, 7], [4, 5], [5, 5]]edges = [(1, 2), (1, 3), (2, 4), (2, 5), (3, 5), (3, 4)]edge_features = [[1, 3], [4, 1], [1, 5], [5, 3], [5, 6], [5, 4]]colors = []edge_colors = []# add nodesfor i in range(1, len(node_features) + 1):    G.add_node(i, feature=str(i) + ':(' + str(node_features[i-1][0]) + ',' + str(node_features[i-1][1]) + ')')    colors.append('#DCBB8A')# add edgesfor i in range(1, len(edge_features) + 1):    G.add_edge(edges[i-1][0], edges[i-1][1], feature='(' + str(edge_features[i-1][0]) + ',' + str(edge_features[i-1][1]) + ')')    edge_colors.append('#3CA9C4')# drawfig, ax = plt.subplots()pos = nx.spring_layout(G)nx.draw(G, pos=pos, node_size=2000, node_color=colors, edge_color='black')node_labels = nx.get_node_attributes(G, 'feature')nx.draw_networkx_labels(G, pos=pos, labels=node_labels, node_size=2000, node_color=colors, font_color='r', font_size=14)edge_labels = nx.get_edge_attributes(G, 'feature')nx.draw_networkx_edge_labels(G, pos, edge_labels=edge_labels, font_size=14, font_color='#7E8877')ax.set_facecolor('deepskyblue')ax.axis('off')fig.set_facecolor('deepskyblue')plt.show()

如下所示:

图神经网络(GNN)的基本原理

其中,每一个节点都有自己的一些特征,比如在社交网络中,每个节点(用户)有性别以及年龄等特征。

5个节点的特征向量依次为:

代码语言:javascript代码运行次数:0运行复制

[[2, 3], [4, 7], [3, 7], [4, 5], [5, 5]]

同样,6条边的特征向量为:

代码语言:javascript代码运行次数:0运行复制

[[1, 3], [4, 1], [1, 5], [5, 3], [5, 6], [5, 4]]

2. 变量定义

图神经网络(GNN)的基本原理

特征向量实际上也就是节点或者边的标签,这个是图本身的属性,一直保持不变。

3. GNN算法

GNN算法的完整描述如下:Forward向前计算状态,Backward向后计算梯度,主函数通过向前和向后迭代调用来最小化损失。

图神经网络(GNN)的基本原理

主函数中:

图神经网络(GNN)的基本原理

上述描述只是一个总体的概述,可以略过先不看。

3.1 Forward

早期的GNN都是RecGNN,即循环GNN。这种类型的GNN基于信息传播机制:GNN通过不断交换邻域信息来更新节点状态,直到达到稳定均衡。节点的状态向量 由以下 函数来进行周期性更新:

图神经网络(GNN)的基本原理
图神经网络(GNN)的基本原理

解析上述公式:对于节点 n ,假设为节点1,更新其状态需要以下数据参与:

图神经网络(GNN)的基本原理

这里的fw只是形式化的定义,不同的GNN有不同的定义,如随机稳态嵌入(SSE)中定义如下:

图神经网络(GNN)的基本原理

由更新公式可知,当所有节点的状态都趋于稳定状态时,此时所有节点的状态向量中都包含了其邻居节点和相连边的信息。

这与图嵌入有些类似:如果是节点嵌入,我们最终得到的是一个节点的向量表示,而这些向量是根据随机游走序列得到的,随机游走序列中又包括了节点的邻居信息, 因此节点的向量表示中包含了连接信息。

千图设计室AI助手 千图设计室AI助手

千图网旗下的AI图像处理平台

千图设计室AI助手 68 查看详情 千图设计室AI助手

证明上述更新过程能够收敛需要用到不动点理论,这里简单描述下:

如果我们有以下更新公式:

图神经网络(GNN)的基本原理

GNN的Foward描述如下:

图神经网络(GNN)的基本原理

解释:

图神经网络(GNN)的基本原理

3.2 Backward

在节点嵌入中,我们最终得到了每个节点的表征向量,此时我们就能利用这些向量来进行聚类、节点分类、链接预测等等。

GNN中类似,得到这些节点状态向量的最终形式不是我们的目的,我们的目的是利用这些节点状态向量来做一些实际的应用,比如节点标签预测。

因此,如果想要预测的话,我们就需要一个输出函数来对节点状态进行变换,得到我们要想要的东西:

图神经网络(GNN)的基本原理

最容易想到的就是将节点状态向量经过一个前馈神经网络得到输出,也就是说gw可以是一个FNN,同样的,fw也可以是一个FNN:

图神经网络(GNN)的基本原理
图神经网络(GNN)的基本原理

因此所有节点的损失可以定义为:

图神经网络(GNN)的基本原理
图神经网络(GNN)的基本原理
图神经网络(GNN)的基本原理
图神经网络(GNN)的基本原理
图神经网络(GNN)的基本原理

因此,在Backward中需要计算以下导数:

图神经网络(GNN)的基本原理

4.总结与展望

本文所讲的GNN是最原始的GNN,此时的GNN存在着不少的问题,比如对不动点隐藏状态的更新比较低效。

由于CNN在CV领域的成功,许多重新定义图形数据卷积概念的方法被提了出来,图卷积神经网络ConvGNN也被提了出来,ConvGNN被分为两大类:频域方法(spectral-based method )和空间域方法(spatial-based method)。2009年,Micheli在继承了来自RecGNN的消息传递思想的同时,在架构上复合非递归层,首次解决了图的相互依赖问题。在过去的几年里还开发了许多替代GNN,包括GAE和STGNN。这些学习框架可以建立在RecGNN、ConvGNN或其他用于图形建模的神经架构上。

GNN是用于图数据的深度学习架构,它将端到端学习与归纳推理相结合,业界普遍认为其有望解决深度学习无法处理的因果推理、可解释性等一系列瓶颈问题,是未来3到5年的重点方向。

因此,不仅仅是GNN,图领域的相关研究都是比较有前景的,这方面的应用也十分广泛,比如推荐系统、计算机视觉、物理/化学(生命科学)、药物发现等等。

以上就是图神经网络(GNN)的基本原理的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/458372.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 02:28:00
下一篇 2025年11月8日 02:28:32

相关推荐

  • html单选框如何添加_在HTML表单中添加单选框【表单】

    HTML单选框需用,同组name值相同以实现互斥;配合label提升可访问性,可用for/id显式关联或嵌套隐式关联;用checked设默认选中;CSS可通过appearance:none和伪元素自定义样式。 如果您需要在HTML表单中添加单选框,必须使用 元素,并确保同一组单选框具有相同的 nam…

    2025年12月23日
    000
  • myeclipse如何创建html_myeclipse创建html流程【方法】

    可在MyEclipse中通过五种方式创建HTML文件:一、在动态Web项目中使用Web→HTML File向导,存入WebContent目录;二、在Java项目中手动建文件夹再新建HTML文件;三、配置HTML模板自动插入标准结构;四、复制现有HTML文件快速复用;五、启用MyEclipse HTM…

    2025年12月23日
    000
  • Selenium WebDriver:通过XPath精确定位特定区域的单选按钮

    本教程旨在指导用户如何在使用selenium webdriver进行自动化测试时,精确地选择网页中特定div容器内的单选按钮组。通过优化xpath定位策略,我们将解决因元素选择器过于宽泛而导致选取到非目标元素的问题,确保自动化操作的准确性和效率。 理解问题:定位的挑战 在使用Selenium进行We…

    2025年12月23日
    000
  • Selenium XPath高级技巧:精准定位特定容器内的单选按钮

    本教程详细介绍了在Selenium自动化测试中,如何利用XPath的强大功能,精准定位并选择特定HTML容器(如div)内的单选按钮。文章通过分析常见定位问题,展示了如何结合类名和文本内容来构建精确的XPath表达式,避免选择到不相关的元素,从而提高自动化脚本的稳定性和准确性。 引言:自动化测试中的…

    2025年12月23日
    000
  • vb怎么运行html_vb运行html步骤【指南】

    VB可通过WebBrowser控件或调用默认浏览器运行HTML。1. 使用WebBrowser控件加载本地或远程HTML页面,VB6需在部件中启用“Microsoft Web Browser”,VB.NET直接拖放控件并调用Navigate方法;2. 通过Shell函数调用rundll32打开默认浏…

    2025年12月23日
    000
  • Selenium:使用XPath精确选择特定区域的单选按钮

    本文旨在解决selenium自动化测试中,当多个ui区域具有相似结构时,如何精确地选择特定div内的单选按钮。通过优化xpath定位策略,结合元素类名和文本内容来唯一标识目标父元素,从而避免选中不必要的元素,提高定位的准确性和脚本的稳定性。 1. 问题背景:宽泛定位的挑战 在进行Web自动化测试时,…

    2025年12月23日
    000
  • Selenium XPath 精确定位:如何选择特定容器内的单选按钮

    本文旨在解决Selenium自动化测试中,当通用选择器捕获过多元素时,如何精确选择特定HTML容器(如div)内的单选按钮。我们将通过优化XPath表达式,结合父元素的类属性和文本内容进行定位,从而实现对目标元素的精准控制,避免不必要的元素干扰,提升测试脚本的稳定性和准确性。 在进行Web自动化测试…

    2025年12月23日
    000
  • 如何在Three.js中动态更改3D模型(如glTF、GLB、FBX)的纹理

    本教程详细介绍了如何在three.js应用中动态更改3d模型的纹理。文章涵盖了纹理加载、目标网格识别以及如何将新纹理应用于特定网格的材质`map`属性。通过示例代码和最佳实践,您将学会如何响应用户选择(例如来自下拉菜单)来更新模型的视觉外观,从而提升应用的交互性和灵活性。 在Three.js中,动态…

    2025年12月23日
    000
  • W3C HTML验证器中Unicode字符路径解析的深度解析与修复

    本文深入探讨了w3c html验证器在处理包含特定unicode字符(如?)的url路径时曾出现的验证错误。该问题源于验证器内部url解析逻辑对utf-16补充字符处理不当,未能正确计算字符索引。文章详细解释了java中utf-16编码与代理对的概念,以及修复方案如何通过引入character.ch…

    2025年12月23日 好文分享
    000
  • Three.js中动态更换3D模型纹理的教程

    本教程详细介绍了如何在Three.js应用中,通过用户选择(如下拉菜单)动态更改GLTF、GLB、FBX等3D模型特定网格的纹理。文章涵盖了纹理加载、目标网格识别、材质更新的核心机制,并提供了代码示例和最佳实践,旨在帮助开发者实现模型外观的实时定制化。 在Three.js中,为3D模型(如GLTF、…

    2025年12月23日
    000
  • 利用R语言通过API和JSON解析高效提取网页链接与数据

    本文旨在指导读者如何使用R语言中的`httr2`包,通过访问网页的底层JSON数据源来高效提取链接地址和下载文件,尤其适用于那些点击后直接触发下载的链接。我们将探讨如何识别、请求、解析JSON数据,并从中提取特定信息,最终实现无需浏览器自动化即可获取所需链接和文件的目的。 1. 挑战与解决方案概述 …

    2025年12月23日
    000
  • 解决JavaScript点击事件与CSS过渡冲突:实现平滑的元素显示与隐藏

    本教程深入探讨了在web开发中,如何解决因css层叠和`opacity`属性导致的javascript点击事件失效问题。通过优化css的`display`属性和事件类名,结合javascript动态添加/移除类,实现元素(如信息框)的平滑过渡显示与隐藏,确保用户交互的正确性和流畅性。 在构建交互式网…

    2025年12月23日
    000
  • FullCalendar响应式视图:根据屏幕尺寸动态调整日历显示

    本教程详细介绍了如何在fullcalendar中实现响应式视图切换。通过利用windowresize事件钩子和changeview方法,我们能够根据浏览器窗口的实时宽度动态调整日历的默认视图,例如在小屏幕上显示“basicday”视图,在大屏幕上显示“agendaweek”视图,从而提升用户体验,确…

    2025年12月23日
    000
  • 使用Python和BeautifulSoup从HTML页面提取H3标签文本

    本教程详细介绍了如何利用python的`requests`库获取网页内容,并结合`beautifulsoup`库高效解析html,精准提取所有` `标签内的文本信息。文章将提供清晰的步骤、完整的代码示例以及重要的注意事项,帮助开发者轻松实现网页数据抓取,适用于需要从复杂html结构中定位特定元素并提…

    2025年12月23日
    100
  • Python BeautifulSoup:高效解析HTML并提取指定标签内容

    本文详细介绍了如何使用python的beautifulsoup库从html页面中高效地提取特定标签(例如` `)的文本内容。教程涵盖了从安装必要的库、获取html内容、使用beautifulsoup解析文档,到最终通过`find_all`方法定位并提取所需文本的完整流程,并提供了详细的代码示例,帮助…

    2025年12月23日
    000
  • rofi菜单一键生成HTML+CSS完整项目结构!

    答案:通过Shell脚本与rofi集成实现HTML+CSS项目一键创建。首先编写脚本生成包含css、js、images目录及基础文件的项目结构,并填充默认HTML内容;接着创建rofi菜单脚本,提供web、blog、dashboard等选项,调用对应项目生成逻辑;最后配置模板预设,在主脚本中添加模板…

    2025年12月23日
    000
  • R语言中通过解析Web服务JSON源获取文件链接的教程

    本教程将指导如何在r语言环境中,利用`httr2`和`tidyverse`库,通过直接访问web服务的底层json数据源来高效获取文件下载链接,例如csv文件。这种方法避免了模拟浏览器交互或直接下载文件,提供了一种更稳定、程序化的数据链接提取策略,并涵盖了从json中解析链接到实际下载文件的完整流程…

    2025年12月23日
    000
  • Mac用Sublime Text创建HTML代码片段提高效率

    首先创建自定义HTML代码片段,在Sublime Text中通过Tools → Developer → New Snippet…生成模板,替换内容为包含div、img、a等标签的CDATA结构,设置tabTrigger如divc、imgt、ahref,并将文件保存为以.sublime-snippet…

    2025年12月23日
    000
  • Windows如何用命令提示符批量创建HTML学习文件?

    可通过命令提示符使用for循环批量生成HTML文件。首先用cd /d D:html_learning进入目标目录,再执行for /l %i in (1,1,10)命令创建page1.html到page10.html基础文件;接着生成含CSS样式的lesson1.html到lesson5.html,内…

    2025年12月23日
    000
  • 如何在TextMate中设置HTML代码审查的处理方法

    通过集成HTML Tidy工具,在TextMate中创建自定义命令实现HTML代码审查,使用终端安装tidy后,通过Bundle Editor添加运行命令,设置快捷键触发,可快速检测并修复HTML问题,提升编码质量。 在TextMate中设置HTML代码审查,主要是通过集成外部工具或使用内置的语法检…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信