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 G can 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 G represents 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 G is directed.

NetworkXError

If the graph G is 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