networkx 2.8.2 Pypi GitHub Homepage
Other Docs
NotesParametersReturnsBackRef
pagerank_numpy(G, alpha=0.85, personalization=None, weight='weight', dangling=None)

PageRank computes a ranking of the nodes in the graph G based on the structure of the incoming links. It was originally designed as an algorithm to rank web pages.

Notes

The eigenvector calculation uses NumPy's interface to the LAPACK eigenvalue solvers. This will be the fastest and most accurate for small graphs.

This implementation works with Multi(Di)Graphs. For multigraphs the weight between two nodes is set to be the sum of all edge weights between those nodes.

Parameters

G : graph

A NetworkX graph. Undirected graphs will be converted to a directed graph with two directed edges for each undirected edge.

alpha : float, optional

Damping parameter for PageRank, default=0.85.

personalization: dict, optional :

The "personalization vector" consisting of a dictionary with a key some subset of graph nodes and personalization value each of those. At least one personalization value must be non-zero. If not specfiied, a nodes personalization value will be zero. By default, a uniform distribution is used.

weight : key, optional

Edge data key to use as weight. If None weights are set to 1.

dangling: dict, optional :

The outedges to be assigned to any "dangling" nodes, i.e., nodes without any outedges. The dict key is the node the outedge points to and the dict value is the weight of that outedge. By default, dangling nodes are given outedges according to the personalization vector (uniform if not specified) This must be selected to result in an irreducible transition matrix (see notes under google_matrix). It may be common to have the dangling dict to be the same as the personalization dict.

Returns

pagerank : dictionary

Dictionary of nodes with PageRank as value.

Returns the PageRank of the nodes in the graph.

See Also

google_matrix
pagerank
pagerank_scipy

Examples

>>> G = nx.DiGraph(nx.path_graph(4))
... pr = nx.pagerank_numpy(G, alpha=0.9)
See :

Back References

The following pages refer to to this document either explicitly or contain code examples using this.

networkx.algorithms.link_analysis.pagerank_alg.pagerank networkx.algorithms.link_analysis.pagerank_alg.google_matrix networkx.algorithms.link_analysis.pagerank_alg.pagerank_numpy networkx.algorithms.link_analysis.pagerank_alg.pagerank_scipy

Local connectivity graph

Hover to see nodes names; edges to Self not shown, Caped at 50 nodes.

Using a canvas is more power efficient and can get hundred of nodes ; but does not allow hyperlinks; , arrows or text (beyond on hover)

SVG is more flexible but power hungry; and does not scale well to 50 + nodes.

All aboves nodes referred to, (or are referred from) current nodes; Edges from Self to other have been omitted (or all nodes would be connected to the central node "self" which is not useful). Nodes are colored by the library they belong to, and scaled with the number of references pointing them


GitHub : /networkx/algorithms/link_analysis/pagerank_alg.py#280
type: <class 'function'>
Commit: