pagerank.py 827 Bytes
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
from __future__ import division

import networkx as nx
from dgl.graph import DGLGraph

DAMP = 0.85
N = 100
K = 10

def message_func(src, dst, edge):
    return src['pv'] / src['deg']

13
14
def update_func(node, accum):
    pv = (1 - DAMP) / N + DAMP * accum
15
16
17
18
19
20
21
    return {'pv' : pv}

def compute_pagerank(g):
    g = DGLGraph(g)
    print(g.number_of_edges(), g.number_of_nodes())
    g.register_message_func(message_func)
    g.register_update_func(update_func)
22
    g.register_reduce_func('sum')
23
24
25
26
27
28
29
30
31
32
33
34
35
    # init pv value
    for n in g.nodes():
        g.node[n]['pv'] = 1 / N
        g.node[n]['deg'] = g.out_degree(n)
    # pagerank
    for k in range(K):
        g.update_all()
    return [g.node[n]['pv'] for n in g.nodes()]

if __name__ == '__main__':
    g = nx.erdos_renyi_graph(N, 0.05)
    pv = compute_pagerank(g)
    print(pv)