背景

最近需要在一个节点数300+万,边400+万的有向图中删除某一些边的子集,但是又需要尽量减少对图的弱连通性的影响。最后的解决方案中一部分是,先将有向图转为无向图,计算边的betweenness,有时也被翻译成中介中心性,然后删除中介中心性较低的边。

定义

betweenness顾名思义,是它作为中介的一种度量。具体是在所有最短路径中,此边通过的最短路径所占的比例。因此betweenness越高,其中介性越高。
cB(e)=∑s,t∈eσ(s,t∣v)σ(s,t)c_B(e) =\sum_{s,t \in e } \frac{\sigma(s, t|v)}{\sigma(s, t)} cB​(e)=s,t∈e∑​σ(s,t)σ(s,t∣v)​
我认为删除中介性更高的边,对图的连通性影响性更大。

实例

建图

import networkx as nx
G = nx.Graph()
G.add_edges_from([[0, 1], [0, 2], [1, 2], [2,3], [3,4], [4,5], [3,5]])
nx.draw(G, with_labels=True)


计算

nx.edge_betweenness_centrality(G, k=None)
>>> {(0, 1): 0.06666666666666667,(0, 2): 0.26666666666666666,(1, 2): 0.26666666666666666,(2, 3): 0.6,(3, 4): 0.26666666666666666,(3, 5): 0.26666666666666666,(4, 5): 0.06666666666666667}

可以看到(2, 3)的中介性最高,(0, 1) (4, 5)的中介性最低,其余几条边的中介性相同,跟预期相同。

大规模图上的边介数

既然edge_betweenness的计算涉及了最短路径,因此计算复杂度一定不低,因此在大规模图上有实现难度。不过networkxedge_betweenness提供了一个k参数,选择sample的节点数目。k越大,其计算的介数准确度越高。
在我的大规模图上,我选择了10,计算时长在一个小时左右。根据返回的edge_betweenness删除边后,图的连通性的影响在可接受范围内。
另外需要注意的是,当设置了k后,返回的edge_betweenness不一定包括所有的边。这里面的具体原理还需要看代码。不过我个人理解,缺失的边的中介性是很低的。

networkx计算边的重要性:边介数或者中介中心性edge_betweenness相关推荐

  1. 使用networkx计算网络的介数中心性

    网络节点的重要性指标介数中心性的计算,使用python的networkx包 import networkx as nxG = nx.Graph()# 从文件@filename中读取网络的adjacen ...

  2. 【电气介数】电气介数及考虑HVDC和FACTS元件的电气介数计算

    1.软件版本 matlab2013b 2.系统概述 1.支路电气介数计算 支路m-n的电气介数计算式如下: 2.节点电气介数计算 节点k的电气介数计算式如下: 其中,F(k)为与节点k连接的边的集合. ...

  3. 复杂网络 介数中心性 java_ego network 介数中心性计算

    下面是求节点介数的代码,介数就是指经过一个点的最短路径的比例,在计算复杂网络中节点重要性的时候会用到. /** * 用来计算介数 * 要计算所有的最短路径,用DIJ计算最短路径的时候我们可以发现一个规 ...

  4. networkx介数_NetworkX 算法列表

    官方网站: http://networkx.github.io/ 3 Algorithms 3.1 Approximations and Heuristics 近似和启发式算法 3.1.1 Conne ...

  5. matlab求点介数程序,matlab_bgl 一个很有用的计算网络中每个节点介数的程序,对 分析 Cloud Computing 云 266万源代码下载- www.pudn.com...

    文件名称: matlab_bgl下载  收藏√  [ 5  4  3  2  1 ] 开发工具: Others 文件大小: 2098 KB 上传时间: 2016-10-26 下载次数: 0 提 供 者 ...

  6. python求边介数

    介数就是指经过一个点的最短路径的比例,在计算复杂网络中节点重要性的时候会用到 https://networkx.org/documentation/stable/reference/algorithm ...

  7. 节点中心性:度中心性、特征向量中心性、Katz中心性、介数中心性

    目录 一.度中心性(Degree Centrality) 二.特征向量中心性(Eigenvector Centrality) 三.Katz中心性(Katz Centrality) 四.介数中心性(Be ...

  8. 利用python求解节点介数和边介数

    利用python求解节点介数和边介数 利用networkx里面的函数betweenness_centrality(G)来求解节点介数和函数edge_betweenness_centrality(G)来 ...

  9. python中心性评价_centrality 计算复杂网络中的节点或边 数中心性,基于python的 工具箱 matlab 238万源代码下载- www.pudn.com...

    文件名称: centrality下载 收藏√  [ 5  4  3  2  1 ] 开发工具: Python 文件大小: 101 KB 上传时间: 2014-03-13 下载次数: 4 详细说明:计算 ...

最新文章

  1. [APIO2018]铁人两项——圆方树+树形DP
  2. Python3各种进制之间的转换方法
  3. Linux 命令之 newgrp -- 登入另一个群组
  4. oracle和mysql数据实时同步_异构数据源的CDC实时同步系统——最终选型实战
  5. spring mvc学习(3):建立第一个动态web项目
  6. python操作word文档中的图片_Python操作word文档插入图片和表格的实例演示
  7. 如何用html构建ios应用,使用HTML5构建iOS原生APP(2)
  8. mysql主从同步忽略一条错误_mysql主从同步出现异常语句跳过错误处理
  9. C++11_范围for循环
  10. 2020计算机顶级大会_2020年顶级公司和专业人员将使用40多种Web工具和服务
  11. Spring经典高频面试题,原来是长这个样子
  12. 花生壳 Linux arm
  13. javaweb面试题总结
  14. python爬取别人qq空间相册_Python_小林的爬取QQ空间相册图片链接程序
  15. (转载)硬盘安装XP64位系统
  16. 对抗样本:知其然,知其所以然
  17. 深度学习-浅层神经网络
  18. UEFI电脑安装Win7并激活
  19. 两个路由器如何通过一根网线组建局域网(非wifi桥接方式)
  20. SpringIOC、AOP

热门文章

  1. 【第十三届蓝桥杯省赛B组】统计子矩阵 (枚举前缀和+双指针)
  2. iphone引用自定义字体 html,在iphone中使用自定义字体
  3. linux netstat未找到命令,运行netstat,提示未找到这个命令
  4. 结构体之引用结构体成员变量
  5. debug tools
  6. RationalDMIS 2020直线度评价
  7. 单片机编程软件很简单(14),Keil单片机编程软件断点设置
  8. 网站底部添加备案号和链接
  9. vue中base64图片展示提示 图片报错:GET data:image/png;base64,undefined net::ERR_INVALID_URL
  10. 数据库系统概论第五版-重点知识点思维导图