1.Weisfeiler-Lehman Algorithm

news2024/9/23 1:34:40

文章目录

    • 1.图同构介绍
    • 2.Weisfeiler-Lehman Algorithm
    • 3.后话
    • 参考资料


欢迎访问个人网络日志🌹🌹知行空间🌹🌹


Weisfeiler-Lehman Algorithm是美国的数学家Boris Weisfeiler在1968年发表的论文the reduction of a graph to a canonical form and an algebra arising during this reduction中提出的判断图同构(Graph Isomorphism)与否的算法。

1.图同构介绍

参考自维基百科

图同构描述的是图论中,两个图之间的完全等价关系。在图论的观点下,两个同构的图被当作同一个图来研究。

只有节点数目相同(即同阶)的两个图才有可能同构。

两个简单图 G G G H H H称为是同构的,当且仅当存在一个将 G G G的节点 1 , . . . , n 1,...,n 1,...,n映射到 H H H的节点 1 , . . . , n 1,...,n 1,...,n的一一对应 σ \sigma σ ,使得 G G G中任意两个节点 i i i j j j相连接,当且仅当 H H H中对应的两个节点 σ i \sigma_{i} σi σ j \sigma_{j} σj相连接。同构可记作 G ≃ H G\simeq H GH

在这里插入图片描述

一组彼此同构的图可称为同构图。

一幅图经常可以有多种不同的方式在纸上或屏幕上画出来,所以两个看起来很不同的图也可能是同构的。尤其当图的节点数比较大时,很难一眼从画出的图上判断它们是否同构。

2.Weisfeiler-Lehman Algorithm

第一部分介绍了什么是图同构Weisfeiler-Lehman算法正是为了用来判断图是否同构的算法,因此也被称为Weisfeiler-Lehman Isomorphism Test,不过现在已经发现,单纯的通过该算法还不能够确保图同构。

图中的节点表示为 v i v_i vi,边表示为 e i e_i ei,节点的集合表示为 V \mathcal{V} V,边的集合表示为 E \mathcal{E} E,如此图可以表示为 G = ( V , E ) \mathcal{G}=(\mathcal{V},\mathcal{E}) G=(V,E)

Weisfeiler-Lehman算法是通过进行多次迭代,然后判断节点上的标签值的个数是否一致来判断图是否同构。

算法中:

  • i i i表示算法迭代的次数
  • n n n表示第 n n n个节点
  • L i , n L_{i,n} Li,n表示节点 v n v_n vn邻居节点标签的集合(multiset,A multiset is a set where elements may appear multiple times.)
  • C i , n C_{i,n} Ci,n表示算法每一次迭代中给每个节点赋予的标签值。 L i , n L_{i,n} Li,n相同的节点 C i , n C_{i,n} Ci,n也相同。

算法步骤:

  • 1)开始时初始化所有节点 C 0 , n = 1 C_{0,n}=1 C0,n=1
  • 2)第 i i i步,对于每个节点 n n n,定义 L i , n 是由 L_{i,n}是由 Li,n是由i-1 步的 步的 步的C_{i-1,m} 组成的 ‘ m u l t i s e t ‘ , 组成的`multiset`, 组成的multiset,m 是节点 是节点 是节点n$的所有邻居节点。
  • 3)计算 C i , n = h a s h ( L i , n ) C_{i,n}=hash(L_{i,n}) Ci,n=hash(Li,n)
  • 4)统计每种标签值节点的个数,重复步骤2)3)N步或算法收敛。

例如:

下图中Graph1Graph2是同构的:

在这里插入图片描述

初始化:

在这里插入图片描述

对于iteration=1

在这里插入图片描述
在这里插入图片描述

对于iteration=2

在这里插入图片描述
在这里插入图片描述

对于iteration=3

在这里插入图片描述
在这里插入图片描述

到第3步可以看到两个图中都是有2个7,1个8,2个9, 因此,两个图是同构的。

3.后话

关于算法作者Boris Weisfeiler,是一个数学家,其本身是犹太人,出生在苏联,后转到美国,但是在1985年于智利神秘失踪,生死未卜。


欢迎访问个人网络日志🌹🌹知行空间🌹🌹


参考资料

  • 1.https://davidbieber.com/post/2019-05-10-weisfeiler-lehman-isomorphism-test/
  • 2.https://en.wikipedia.org/wiki/Boris_Weisfeiler

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/188301.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Flask WebSocket学习笔记

WebSocket简介:WebSocket是一种全新的协议,随着HTML5的不断完善,越来越多的现代浏览器开始全面支持WebSocket技术了,它将TCP的Socket(套接字)应用在了webpage上,从而使通信双方建立起一个保持在…

Java面向对象基础

文章目录面向对象一、类和对象1. 类的介绍2. 类和对象的关系3. 类的组成4. 创建对象和使用对象的格式二、对象内存图1. 单个对象内存图2. 两个对象内存图3. 两个引用指向相同内存图三、成员变量和局部变量四、this 关键字1. this 可以解决的问题2. this 介绍3. this 内存图五、…

学术的快乐来源

文章目录我的核心快乐来源:其他非核心快乐源泉知乎搜到的别人的快乐来源作此文,以便懈怠时候看看,能够聊表安慰。 ——题记 抱着给自己枯燥无聊学术生涯找点乐子的想法, 我决定仔细思考一下自己做学术的时候有哪些快乐的地方&…

C++关于开源包7zip压缩工具的编译及使用

1、7zip的配置 7-Zip是一款免费开源的压缩与解压软件,基本能够满足绝大多数常见的压缩和解压文件需求,此外还支持了分卷压缩和解压,非常好用。但是调用7-zip库需要用到一个叫bit7z的库,bit7z是一个C静态库,其封装了简单…

MySQL 中主从之间是怎样保证数据一致的呢?

在我们日常的工作中,处理 MySQL 数据库相关问题时,我相信绝大多数 DBA 处理最棘手的问题就是数据库主从数据不一致的问题。 处理过关于 MySQL 数据库主从数据不一致的朋友一定印象非常深刻,因为稍有不慎就会将造成原有数据的丢失&#xff0c…

精益安灯电子看板实现了实时监测

众所周知,智能工厂的规划建设是一个十分复杂的系统工程。所以安灯电子看板是精益生产中一一个重要组成要素,可以提升工厂生产车间的过程管理,生产数据做的信息化、目视化;信息快捷化、生产工序透明化等,是提高生产率的…

自动控制原理笔记-根轨迹的概念-根轨迹方程

目录 根轨迹的基本概念: 根轨迹的概念:当开环系统某一参数从 0 到∞变化时,闭环极点在S 平面上变化所描绘出的轨迹。 闭环零极点与开环零极点之间的关系: 根轨迹方程: 开环增益于根轨迹间的关系: 闭环系…

excel 格式化日期为字符串

最近经常遇到excel打开文件的时候,excel自动将yyyy-MM-dd HH:mm:ss (如:2022-01-21 12:12:12 )之类的时间的自动转为这样的格式列,2022/1/21 12:12:12 ,导致有想从excel/csv格式 中复制原始日期格式比较麻烦…

【软件测试】一个真正的测试面试过程,我比面试官还狡猾......

目录:导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜)前言 先卖个关子&#xf…

关羽这灵敏度你们爱了吗?#走位 #游戏外设

关羽这灵敏度你们爱了吗?#走位 #游戏外设 关羽这灵敏度你们爱了吗?#走位 #游戏外设

var、let、const之间的区别

说一下var、let、const之间的区别一、var二、let三、const四、var、let 、const的区别?一、var 用var声明的变量既是全局变量,也是顶层变量 注意:顶层对象,在浏览器环境指的是window对象,在Node指的是global对象。 var…

老杨说运维 | AIOps如何助力实现全面可观测性(下)

上期我们讲到可观测性是什么,以及它能给企业带来的价值, 戳→「老杨说运维 | AIOps如何助力实现全面可观测性(上)」一键回看上期精彩内容。 说完了什么是可观测性,这期我们来看看可观测性是如何落地实践的。 一、可观…

若依配置教程(五)数据权限的使用及配置

文章目录一、Controller模块二、Mapper.xml三、在Impl服务层加入权限注解四、分配数据权限若依文档 学会了前几篇文章如何新建模块和生成代码,这篇接下来介绍数据权限的配置和使用: 首先,在建立数据库表的时候,必须要添加user_id…

深入理解spring三级缓存解决循环依赖的设计思路

说到这个话题的时候,很多人再熟悉不过了,因为听到太多了,而且百度一大堆,但是理解到什么程度了呢,或者说只是知道这回事,但是为什么这样设计,代码中有什么可以借鉴的,在实际业务中有…

Jmeter和JDK下载安装及环境变量配置详细教程

写在最前面的话,jmeter安装部署依赖java环境,所以得安装JDK java环境检查 命令行输入:java -version 如果出现以下内容,说明java环境已安装,无需理会,如果没有,需要安装JDK 一、下载并安装JDK…

PSP模拟器截图CG的高清化-Waifu2x

由PSP游戏本体提取CG图片直接超分自然是比较舒服的,但实际上因了加密等诸多问题,甚或不如直接模拟器截了图进行处理来得方便 1. 模拟器设置 如果要截图的话,自然是以得到更好的效果为宜,于是可以对模拟器进行一些基本的设置。 对…

Java两大工具库:Commons和Guava(3)

您好,我是湘王,这是我的CSDN博客。值此新春佳节,我给您拜年啦~祝您在新的一年中所求皆所愿,所行皆坦途,展宏“兔”,有钱“兔”,多喜乐,常安宁!虽然Apache Com…

【33】C语言 | 联合体详解

目录 1、联合类型的定义 2、联合的特点 3、联合大小的计算 1、联合类型的定义 联合也是一种特殊的自定义类型这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间《所以联合也叫共用体)先看下面代码输出什么? union Un {char c;int …

我用css3为好友胡歌的宝宝做了一个动画照片墙

软件人生风雨十年,仙剑一过去也有十年有余了,和胡歌认识那么久,今日喜闻好友胡歌生宝宝的消息,惊喜之余用css3为胡歌的宝宝做了动画照片墙的模板效果。 目录 1. 实现思路 2. 墙体的实现 3. 选取模板素材,进行图片元…

虹科案例 | 石油天然气行业CFD高性能计算解决方案

公司简介 DNV GL 是全球领先的能源、石油和海事行业风险管理及资产绩效提升的软件供应商,主要为客户提供全面的风险管理和各类评估认证服务,认证涉及信息通信技术、汽车及航空天、食品与饮料、医疗等方面。 DNV GL以让世界更安全、更智能、更环保为使命…