kemeny_constant#
- kemeny_constant(G, *, weight=None)[source]#
- Returns the Kemeny constant of the given graph. - The Kemeny constant (or Kemeny’s constant) of a graph - Gcan be computed by regarding the graph as a Markov chain. The Kemeny constant is then the expected number of time steps to transition from a starting state i to a random destination state sampled from the Markov chain’s stationary distribution. The Kemeny constant is independent of the chosen initial state [1].- The Kemeny constant measures the time needed for spreading across a graph. Low values indicate a closely connected graph whereas high values indicate a spread-out graph. - If weight is not provided, then a weight of 1 is used for all edges. - Since - Grepresents a Markov chain, the weights must be positive.- Parameters:
- GNetworkX graph
- weightstring or None, optional (default=None)
- The edge data key used to compute the Kemeny constant. If None, then each edge has weight 1. 
 
- Returns:
- Kfloat
- The Kemeny constant of the graph - G.
 
- Raises:
- NetworkXNotImplemented
- If the graph - Gis directed.
- NetworkXError
- If the graph - Gis not connected, or contains no nodes, or has edges with negative weights.
 
 - Notes - The implementation is based on equation (3.3) in [2]. Self-loops are allowed and indicate a Markov chain where the state can remain the same. Multi-edges are contracted in one edge with weight equal to the sum of the weights. - References [1]- Wikipedia “Kemeny’s constant.” https://en.wikipedia.org/wiki/Kemeny%27s_constant [2]- Lovász L. Random walks on graphs: A survey. Paul Erdös is Eighty, vol. 2, Bolyai Society, Mathematical Studies, Keszthely, Hungary (1993), pp. 1-46 - Examples - >>> G = nx.complete_graph(5) >>> round(nx.kemeny_constant(G), 10) 3.2