spring_layout#
- spring_layout(G, k=None, pos=None, fixed=None, iterations=50, threshold=0.0001, weight='weight', scale=1, center=None, dim=2, seed=None, store_pos_as=None)[source]#
Position nodes using Fruchterman-Reingold force-directed algorithm.
The algorithm simulates a force-directed representation of the network treating edges as springs holding nodes close, while treating nodes as repelling objects, sometimes called an anti-gravity force. Simulation continues until the positions are close to an equilibrium.
There are some hard-coded values: minimal distance between nodes (0.01) and “temperature” of 0.1 to ensure nodes don’t fly away. During the simulation,
k
helps determine the distance between nodes, thoughscale
andcenter
determine the size and place after rescaling occurs at the end of the simulation.Fixing some nodes doesn’t allow them to move in the simulation. It also turns off the rescaling feature at the simulation’s end. In addition, setting
scale
toNone
turns off rescaling.- Parameters:
- GNetworkX graph or list of nodes
A position will be assigned to every node in G.
- kfloat (default=None)
Optimal distance between nodes. If None the distance is set to 1/sqrt(n) where n is the number of nodes. Increase this value to move nodes farther apart.
- posdict or None optional (default=None)
Initial positions for nodes as a dictionary with node as keys and values as a coordinate list or tuple. If None, then use random initial positions.
- fixedlist or None optional (default=None)
Nodes to keep fixed at initial position. Nodes not in
G.nodes
are ignored. ValueError raised iffixed
specified andpos
not.- iterationsint optional (default=50)
Maximum number of iterations taken
- threshold: float optional (default = 1e-4)
Threshold for relative error in node position changes. The iteration stops if the error is below this threshold.
- weightstring or None optional (default=’weight’)
The edge attribute that holds the numerical value used for the edge weight. Larger means a stronger attractive force. If None, then all edge weights are 1.
- scalenumber or None (default: 1)
Scale factor for positions. Not used unless
fixed is None
. If scale is None, no rescaling is performed.- centerarray-like or None
Coordinate pair around which to center the layout. Not used unless
fixed is None
.- dimint
Dimension of layout.
- seedint, RandomState instance or None optional (default=None)
Used only for the initial positions in the algorithm. Set the random state for deterministic node layouts. If int,
seed
is the seed used by the random number generator, if numpy.random.RandomState instance,seed
is the random number generator, if None, the random number generator is the RandomState instance used by numpy.random.- 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
Examples
>>> G = nx.path_graph(4) >>> pos = nx.spring_layout(G) >>> # supress the returned dict and store on the graph directly >>> _ = nx.spring_layout(G, seed=123, store_pos_as="pos") >>> nx.get_node_attributes(G, "pos") {0: array([-0.61520994, -1. ]), 1: array([-0.21840965, -0.35501755]), 2: array([0.21841264, 0.35502078]), 3: array([0.61520696, 0.99999677])}
# The same using longer but equivalent function name >>> pos = nx.fruchterman_reingold_layout(G)