Нарисуйте сеть и сгруппированные вершины одного сообщества или раздела
Мне нужно посмотреть (нарисовать или построить) структуру сообществ в сетях
У меня есть это:
import igraph
from random import randint
def _plot(g, membership=None):
layout = g.layout("kk")
visual_style = {}
visual_style["edge_color"] = "gray"
visual_style["vertex_size"] = 30
visual_style["layout"] = layout
visual_style["bbox"] = (1024, 768)
visual_style["margin"] = 40
for vertex in g.vs():
vertex["label"] = vertex.index
if membership is not None:
colors = []
for i in range(0, max(membership)+1):
colors.append('%06X' % randint(0, 0xFFFFFF))
for vertex in g.vs():
vertex["color"] = str('#') + colors[membership[vertex.index]]
visual_style["vertex_color"] = g.vs["color"]
igraph.plot(g, **visual_style)
if __name__ == "__main__":
karate = igraph.Nexus.get("karate")
cl = karate.community_fastgreedy()
membership = cl.as_clustering().membership
_plot(karate, membership)
Но вершины распространены. В других сетях этот результат очень хуже.
Я хочу, чтобы вершины были сгруппированы по цвету в похожей области.
Например: