PageRank Explained Example 11

#!/usr/bin/perl

print "Content-Type: text/html\n\n<pre>\n";

$damp = 0.85;
$a = $b = $c = $d = $e = $f = $g = $h = 0;
$iterate = 40; # loop 40 times

# Plain Heirarchical
# forward links
# a -> b    - 1 outgoing links    - home
# b -> a,c    - 2 outgoing link    - about
# c -> a,d    - 2 outgoing link    - products
# d -> a    - 1 outgoing links    - more info

# i.e. "backward" links (what's pointing to me?)
# a <= b/2, c/2, d
# b <= a
# c <= b/2
# d <= c/2
while ($iterate--) {
    printf("a: %.5f b: %.5f c: %.5f d: %.5f\n", $a, $b, $c, $d);

    $a = 1 - $damp + $damp * ($b/2 + $c/2 + $d);
    $b = 1 - $damp + $damp * ($a);
    $c = 1 - $damp + $damp * ($b/2);
    $d = 1 - $damp + $damp * ($c/2);
}
printf("Average pagerank = %.4f\n", ($a + $b + $c + $d) / 4); 
print("</pre><a href=/google-page-rank/#ex11>Back to example 11</a>");

Run this program

Back to PageRank Explained Example 11