spectral_layout#
- spectral_layout(G, weight='weight', scale=1, center=None, dim=2, store_pos_as=None)[source]#
Position nodes using the eigenvectors of the graph Laplacian.
Using the unnormalized Laplacian, the layout shows possible clusters of nodes which are an approximation of the ratio cut. If dim is the number of dimensions then the positions are the entries of the dim eigenvectors corresponding to the ascending eigenvalues starting from the second one.
- Parameters:
- GNetworkX graph or list of nodes
A position will be assigned to every node in G.
- weightstring or None optional (default=’weight’)
The edge attribute that holds the numerical value used for the edge weight. If None, then all edge weights are 1.
- scalenumber (default: 1)
Scale factor for positions.
- centerarray-like or None
Coordinate pair around which to center the layout.
- dimint
Dimension of layout.
- store_pos_asstr, default None
If non-None, the position of each node will be stored on the graph as an attribute with this string as its name, which can be accessed with
G.nodes[...][store_pos_as]
. The function still returns the dictionary.
- Returns:
- posdict
A dictionary of positions keyed by node
Notes
Directed graphs will be considered as undirected graphs when positioning the nodes.
For larger graphs (>500 nodes) this will use the SciPy sparse eigenvalue solver (ARPACK).
Examples
>>> G = nx.path_graph(4) >>> pos = nx.spectral_layout(G) >>> # supress the returned dict and store on the graph directly >>> _ = nx.spectral_layout(G, store_pos_as="pos") >>> nx.get_node_attributes(G, "pos") {0: array([-1. , 0.76536686]), 1: array([-0.41421356, -0.76536686]), 2: array([ 0.41421356, -0.76536686]), 3: array([1. , 0.76536686])}