首頁  >  文章  >  後端開發  >  php實作PageRank的實例

php實作PageRank的實例

不言
不言原創
2018-07-05 16:24:021559瀏覽

這篇文章主要介紹了關於php實作PageRank的實例,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

php簡單實作PageRank演算法

使用的web site模型

<?php
header("Content-type:text/html; charset=utf-8");
class PageRank{
    public $map = [];    
    public $rank = [];    
    public $inputList = []; // example web &#39;a&#39; (has input link): web &#39;b&#39;

    public $size;    
    public $keyValue = 0.85;    
    public function __construct(array $map) {
        $this->map = $map;        
        $this->size = count($this->map);
    }    //init rank score and transform &#39;map&#39; format to &#39;inputList&#39; format
    public function init()
    {
        $size = $this->size;        
        foreach ($this->map as $key => $value) {            
        $this->inputList[$key] = [];
        }        foreach ($this->map as $key => $value) {            
        $this->rank[$key] = 1/$size;            
        foreach ($value as $v) {                
        if (empty($this->inputList[$v])) {                    
        $this->inputList[$v][] = $key;
                } else {
                    array_push($this->inputList[$v], $key);
                }
            }

        }
    }    public function caculate()
    {
        $tmp = $this->rank;        
        $keyValue = $this->keyValue;        
        $size = $this->size;        
        foreach ($this->inputList as $key => $value) {            
        $score = (1 - $keyValue)/$size;            
        foreach ($value as $v) {                
        $cc = count($this->map[$v]);                
        if ($cc) {                    
        $score += ($keyValue*(1/$cc * $this->rank[$v]));
                }
            }            $tmp[$key] = $score;
        }        $this->rank = $tmp;
    }


}$map = [        &#39;a&#39; => [&#39;b&#39;, &#39;c&#39;, &#39;d&#39;],// web &#39;a&#39; (has out link): web &#39;b&#39;, web &#39;c&#39;, web &#39;d&#39;
        &#39;b&#39; => [&#39;a&#39;, &#39;d&#39;],        &#39;c&#39; => [&#39;b&#39;],        &#39;d&#39; => [&#39;b&#39;, &#39;c&#39;],
];$example = new PageRank($map);
$example->init();
echo &#39;<pre class="brush:php;toolbar:false">&#39;;for ($i = 0; $i < 10; $i++) {    
$example->caculate();
    var_dump($example->rank);
}

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

php 透過html-table形式完成excel下載的功能實作

##php身分證識別ORC的方法實作

以上是php實作PageRank的實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn