pygraphviz_layout#
- pygraphviz_layout(G, prog='neato', root=None, args='')[source]#
Create node positions for G using Graphviz.
- Parameters:
- GNetworkX graph
A graph created with NetworkX
- progstring
Name of Graphviz layout program
- rootstring, optional
Root node for twopi layout
- argsstring, optional
Extra arguments to Graphviz layout program
- Returns:
- node_posdict
Dictionary of x, y, positions keyed by node.
Notes
If you use complex node objects, they may have the same string representation and GraphViz could treat them as the same node. The layout may assign both nodes a single location. See Issue #1568 If this occurs in your case, consider relabeling the nodes just for the layout computation using something similar to:
>>> H = nx.convert_node_labels_to_integers(G, label_attribute="node_label") >>> H_layout = nx.nx_agraph.pygraphviz_layout(G, prog="dot") >>> G_layout = {H.nodes[n]["node_label"]: p for n, p in H_layout.items()}
Note that some graphviz layouts are not guaranteed to be deterministic, see graphviz/graphviz#1767 for more info.
Examples
>>> G = nx.petersen_graph() >>> pos = nx.nx_agraph.graphviz_layout(G) >>> pos = nx.nx_agraph.graphviz_layout(G, prog="dot")