首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用networkx查找每个集群的模块化

使用networkx查找每个集群的模块化
EN

Stack Overflow用户
提问于 2020-12-03 19:48:15
回答 1查看 796关注 0票数 0

我有一个图,我试图找到每个集群的模块性。因此,为了找到这一点,我实现了以下步骤:

  1. 我找到了图中最大的连通组件(GiantCC)
  2. 我使用greedy_modularity社区函数找到了图中的所有社区
  3. 现在,我试图使用networkx中的模块化函数来寻找集群的模块化,而im得到了一个错误。

这是我的代码:

代码语言:javascript
复制
cc = sorted(nx.connected_components(g), key=len, reverse=True)
giantCC = g.subgraph(cc[0])
print("Giant cc size: " + str(giantCC.number_of_nodes()))

communities = list(greedy_modularity_communities(giantCC))
communities = sorted(communities, key=len, reverse=True)
print('Number of clusters: ' + str(len(communities)))
communities = [list(x) for x in communities]

cluster_modularity = nx_comm.modularity(giantCC, communities[0])
print('Modularity: ' + str(cluster_modularity))

当我调用函数模块化时,我得到以下错误:

为什么我会犯这个错误?

EN

回答 1

Stack Overflow用户

发布于 2020-12-04 12:19:58

问题是,您正在使用的模块化计算函数(这一个)使用所有共享来计算模块化,因为它是网络分区的值。

所以你应该这样用它:

代码语言:javascript
复制
cluster_modularity = nx_comm.modularity(giantCC, communities)
print('Modularity: ' + str(cluster_modularity))

此外,我还建议使用路易文启发式方法对图进行分区,使用此方法的networkX的API已经可以使用这里

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65133066

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档