>  기사  >  백엔드 개발  >  PageRank를 구현하는 PHP의 예

PageRank를 구현하는 PHP의 예

不言
不言원래의
2018-07-05 16:24:021559검색

이 글에서는 특정 참고값을 가지고 있는 PageRank를 PHP로 구현하는 방법에 대한 예제를 주로 소개합니다. 이제 필요한 친구들이 참고할 수 있도록 공유하겠습니다.

php 간단한 구현 PageRank Algorithm#🎜 🎜#

使用的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 테이블 형식으로 엑셀 다운로드 기능 완성
#🎜🎜 #

php 신분증 식별 ORC 방식 구현

위 내용은 PageRank를 구현하는 PHP의 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.