[英]How can I visualize temporal network using graph-tool?
我在grap-tool(Python 3.4)中有20个有向图,并且所有图都有相同的节点名称(它是一个属性,称为“名称”),但是在连接和属性方面有所不同。
我正在尝试绘制随时间变化的网络(即,边缘在每个时间步长如何变化以及颜色等属性如何变化)。 为此,我需要为所有图固定节点的位置。
我尝试了这个:
import graph_tool.all as gt
## networks = {dictionary of time as the key and the Graph as the value}
#getting the positions of the nodes once that should be fixed across Graphs
initial_pos = gt.arf_layout(networks[0],weight=None, d=0.5,
a=10, dt=0.001, epsilon=1e-06, max_iter=100, pos=None, dim=2)
for round_id in range(0,20):
G = networks[round_id]
fixed_pos = gt.arf_layout(G, max_iter=0, pos=initial_pos)
deg = G.degree_property_map("in")
deg.a = 15 * deg.a + 25
gt.graph_draw(
G,
#pos=fixed_pos,
vertex_fill_color=G.vertex_properties["color"],
vertex_font_size=18,
vertex_size = deg,
vertex_shape = G.vertex_properties["shape"],
edge_pen_width = 5,
output_size=(1000, 1000),
output=("{0}.pdf".format(round_id))
)
但这给了我以下错误:
---------------------------------------------------------------------------
AttributeError Traceback (most recent call last)
<ipython-input-68-4efd39b32b83> in <module>()
5 #f, ax = plt.subplots(nrows=1, ncols=1, figsize=(17, 10), sharex=True)
6 G = nx2gt(networks[round_id])
----> 7 fixed_pos = gt.arf_layout(G, max_iter=0, pos=initial_pos)
8 deg = G.degree_property_map("in")
9 deg.a = 15 * deg.a + 25
/Users/amaatouq/anaconda/lib/python3.4/site-packages/graph_tool/draw/__init__.py in arf_layout(g, weight, d, a, dt, epsilon, max_iter, pos, dim)
393
394 ug = GraphView(g, directed=False)
--> 395 libgraph_tool_layout.arf_layout(ug._Graph__graph, _prop("v", g, pos),
396 _prop("e", g, weight), d, a, dt, max_iter,
397 epsilon, dim)
/Users/amaatouq/anaconda/lib/python3.4/site-packages/graph_tool/__init__.py in _prop(t, g, prop)
177 raise ValueError("Expected '%s' property map, got '%s'" %
178 (names[t], names[prop.key_type()]))
--> 179 return pmap._get_any()
180
181
/Users/amaatouq/anaconda/lib/python3.4/site-packages/graph_tool/__init__.py in _get_any(self)
389 g = self.get_graph()
390 if t == "v":
--> 391 N = g.num_vertices(True)
392 elif t == "e":
393 N = g.edge_index_range
AttributeError: 'NoneType' object has no attribute 'num_vertices'
似乎是arf_layout()中的错误。 您可以通过以下方法解决此问题:
initial_pos = networks[0].own_property(initial_pos)
在进一步使用之前。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.