谷歌PageRank算法
1. 从Google网页排序到PageRank算法
(1)谷歌网页怎么排序?
- 先对搜索关键词进行分词,如“技术社区”分词为“技术”和“社区”;
- 根据建立的倒排索引返回同时包含分词后结果的网页;
- 将返回的网页相关性(类似上篇文章所讲的文本相似度)网页,相关性越高排名越靠前
(2)怎么处理垃圾网页?
那么问题来了,假如有某个垃圾网页中虽然也包含大量的查询词,但却并非满足用户需要的文档,因此,页面本身的重要性在网页排序中也起着很重要的作用。
(3)如何度量网页本身的重要性?
实际上互联网上的每一篇HTML文档除了包含文本、图片、视频等信息外,还包含了大量的链接关系,利用这些链接关系,能够发现某些重要的网页,其中网页是节点,网页间的链接关系是边。
如上图,某网页1链向网页2,则可以认为网页1觉得网页2有链接价值,是比较重要的网页。某网页被指向的次数越多,则它的重要性越高;越是重要的网页,所链接的网页的重要性也越高。
通过下图我们可以更形象地看出链向网页E的链接远远大于链向网页C的链接,但是网页C的重要性却大于网页E。这是因为网页C被网页B所链接,而网页B有很高的重要性。
(4)PageRank核心思想
PageRank对网页的排序可以独立于用户搜索进行。如果一个网页被很多其它网页所链接,说明它受到普遍的承认和信赖,那么它的排名就高。这就是 Page Rank 的核心思想。当然 Google 的 Page Rank 算法实际上要复杂得多。比如说,对来自不同网页的链接对待不同,本身网页排名高的链接更可靠,于是给这些链接予较大的权重。
通俗理解,我们可以将互联网中的网页理解成我们现实中的每个人,人与人之间的联系就类似于网页与网页之间联系,一般人的社交影响力是跟其人脉的广度与人脉的质量有关,网页也同理,其重要性也跟网页的被链的数量与质量有关。
具体参考:PageRank算法讲解;PageRank算法--从原理到实现
2 PageRank的python实现
2.1 需求
利用PageRank随机浏览模型求如下图个网页的PageRank值。
即网页之间的关系如下表格:
链接源ID | 链接目标 ID |
---|---|
1 | 2,3,4,5, 7 |
2 | 1 |
3 | 1,2 |
4 | 2,3,5 |
5 | 1,3,4,6 |
6 | 1,5 |
7 | 5 |
2.2 Python实现
"""
Created on Sun Jan 8 23:41:29 2017 @author: whenif
""" import numpy as np
import networkx as nx
import matplotlib.pyplot as plt def getGm(A):
'''
功能:求状态转移概率矩阵Gm
@A:网页链接图的邻接矩阵
'''
Gm = []
for i in range(len(A)):
cnt = 0
for j in range(len(A[i])):
if A[i][j] != 0:
cnt += 1
tran_prob = 1/cnt#转移概率
Gm_tmp = []
for j in range(len(A[i])):
Gm_tmp.append(tran_prob*A[i][j])
Gm.append(Gm_tmp)
Gm = np.transpose(Gm)
return Gm def getBaseLev(N):
'''
功能:计算网页所获得的基本级别(1-P)*e/n
@N:网页总个数
'''
P = 0.85
e = np.ones(N)
R = [ [(1-P)*i*1/N] for i in e ]
return R def getPR(P,Gm,R,PR):
'''
功能:获取PR值
@P:加权系数,通常取 0.85 左右,按照超链接进行浏览的概率
@Gm:状态转移概率矩阵
@R:网页所获得的基本级别
@PR:每个网页节点的PageRank值
'''
#状态转移概率矩阵Gm与PR值相乘矩阵相乘
Gm_PR = np.dot(Gm,PR)
#矩阵乘以常数P
P_Gm_PR = P*Gm_PR
#矩阵相加
new_PR = P_Gm_PR+R #PR=P*Gm'PR+(1-d)*e/n PageRank算法的核心
return new_PR def res_vis(A,PR):
'''
将计算出来的值进行可视化展示
@A:网页链接图的邻接矩阵
@PR:每个网页节点最终的PageRank值
'''
#G=nx.Graph()构造的是无向图, G=nx.DiGraph()构造的是有向图
#初始化有向图,节点数为7,edge(边)被创造的随机概率
all_edges = []
for i in range(7):
for j in range(len(A)):
if A[i][j]==1:
all_edges.append([i+1,j+1])
#(1)初始化有向图
G = nx.DiGraph()
#(2)添加节点
G.add_nodes_from(range(1,len(A)))
#(3)添加有向边
G.add_edges_from(all_edges)
#(4)添加PR值
pr = {}
for i in range(len(PR)):
pr[i+1] = PR[i][0]
# (5)画图
layout = nx.spring_layout(G)
plt.figure(1)
nx.draw(G, pos=layout, node_size=[x * 6000 for x in pr.values()],
node_color='m',with_labels=True)
plt.show() def main():
#初始化参数
N = 7 #网页个数
P = 0.85 #一个加权系数,通常取 0.85 左右,按照超链接进行浏览的概率
#网页链接图的邻接矩阵,每一列表示一个网页的出度
A = np.array([[0,1,1,0,1,1,0],
[1,0,1,1,0,0,0],
[1,0,0,1,1,0,0],
[1,0,0,0,1,0,0],
[1,0,0,1,0,1,1],
[0,0,0,0,1,0,0],
[1,0,0,0,0,0,0]])
A = np.transpose(A) #转置
#初始化PR值为0
new_PR = []
for i in range(N):
new_PR.append([0])
count = 0#迭代计数器
while True:
PR = new_PR
R = getBaseLev(N)
Gm = getGm(A)
new_PR = getPR(P,Gm,R,PR)
count = count +1
print("第 %s 轮迭代" % count)
print(str(round(new_PR[0][0],5))
+"\t" + str(round(new_PR[1][0],5))
+ "\t" + str(round(new_PR[2][0],5))
+ "\t" + str(round(new_PR[3][0],5))
+ "\t" + str(round(new_PR[4][0],5))
+ "\t" + str(round(new_PR[5][0],5))
+ "\t" + str(round(new_PR[6][0],5)))
#设置迭代条件
if ( round(PR[0][0],5)==round(new_PR[0][0],5)
and round(PR[1][0],5)==round(new_PR[1][0],5)
and round(PR[2][0],5)==round(new_PR[2][0],5)
and round(PR[3][0],5)==round(new_PR[3][0],5)
and round(PR[4][0],5)==round(new_PR[4][0],5)
and round(PR[5][0],5)==round(new_PR[5][0],5)
and round(PR[6][0],5)==round(new_PR[6][0],5)):
break
print("-------------------")
print("PageRank值已计算完成")
res_vis(A,new_PR) if __name__ == '__main__':
main()
2.3 结果与分析
(1)迭代结果
第 1 轮迭代
0.02143 0.02143 0.02143 0.02143 0.02143 0.02143 0.02143
第 2 轮迭代
0.06241 0.04025 0.0357 0.02963 0.05846 0.02598 0.02507
......
第 57 轮迭代
0.28026 0.15875 0.13887 0.10821 0.18418 0.06057 0.06907
第 58 轮迭代
0.28026 0.15875 0.13887 0.10821 0.18418 0.06057 0.06907
-------------------
PageRank值已计算完成
(2)可视化结果
其中圆圈编号表示网页ID,圆圈大小表示PR值大小,连线表示网页之间的关系,有带黑色箭头表示出度方向。
(3)结果汇总
名次 | PageRank值 | 网页ID | 发出链接ID | 被链接ID |
---|---|---|---|---|
1 | 0.28026 | 1 | 2,3,4,5,7 | 2,3,5,6 |
2 | 0.18418 | 5 | 1,3,4,6 | 1,4,6,7 |
3 | 0.15875 | 2 | 1 | 1,3,4 |
4 | 0.13887 | 3 | 1,2 | 1,4,5 |
5 | 0.10821 | 4 | 2,3,5 | 1,5 |
6 | 0.06907 | 7 | 5 | 1 |
7 | 0.06057 | 6 | 1,5 | 5 |
(4)结果分析
- 被链接个数越多其PageRank值越大,当被链接个数相同则发出链接个数越多其PageRank值越大;
- ID=1的页面的PageRank值是0.28026,占据全体接近三分之一,成为了第1位。从可视化图与结果汇总表格可以看出,因为ID=1页面是链出链接和链入链接最多的页面,也可以理解它是最受欢迎的页面。
同时需要注意的是在PageRank值排在第3位的ID=2页面,被3个链接所链接,而只有面向ID=1页面发出一个链接,因此(面向ID=1页面的)链接就得到ID=2的所有的PageRank值。
附另一个简单的PageRank程序:
from numpy import * a = array([[0,1,1,0],
[1,0,0,1],
[1,0,0,1],
[1,1,0,0]],dtype = float) #dtype指定为float def graphMove(a): #构造转移矩阵
c = zeros((a.shape),dtype = float)
for i in range(a.shape[0]):
for j in range(a.shape[1]):
c[i][j] = a[i][j] / (a[:, j].sum()) #完成初始化分配
return c def pageRank(p,m,v): #计算pageRank值
#判断pr矩阵是否收敛,(v == p*dot(m,v) + (1-p)*v).all()判断前后的pr矩阵是否相等,若相等则停止循环
while((v == p*dot(m,v) + (1-p)*v).all()==False):
v = p*dot(m,v) + (1-p)*v
return v if __name__=="__main__":
M = graphMove(a)
pr = array([float(1)/M.shape[0] for _ in range(M.shape[0])]) #pr值的初始化
p = 0.8 #引入浏览当前网页的概率为p,假设p=0.8
print pageRank(p,M,pr) # 计算pr值
3 应用场景
在数据分析我们经常需要从用户的角度思考问题,如用户购买路径,用户之所以没产生购买,那么到底是在哪个环节出现了问题?基于用户还有许许多多的分析问题,如流失用户分析、流失用户预警、用户信用度分析等。
从基于用户的分析我们可以延伸到用户与信息、用户与商品、用户与用户之间的分析,当然这三点对号入座的便分别是BAT的基因所在,其中人与人之间的分析即是社交关系分析,这也是PageRank适合的领域之一。在不同行业的应用场景不用,如以下应用场景:
- 微信、微博等应用的社交网络分析,可以实现基于用户的相似度的内容推荐、可以挖掘用户的价值、用户的社交影响力等;电商如京东等可利用用户关系,在一定程度上协助风险控制(抓刷单等)。
- 在电信行业中利用交往圈数据可以得到用户的社交影响力,从而在一定程度上可以协助垃圾短信等的治理;
- 文献重要性研究(引用与被引用)
- ......
后记
数据分析与挖掘很多都是从人出发,逐渐延伸到人与人,甚至是人、人与人在时间与空间上的表现,其中人与人之间的关系可以说是很重要的一环,所以个人觉得PageRank还是有挺大的应用性,在工作中也是深有体会。当然文中只是举了简单的例子并实现,代码可优化的地方应该不少,望各路小伙伴一起交流一起进步。
链接:http://www.jianshu.com/p/5657910d7df6
谷歌PageRank算法的更多相关文章
- 谷歌pagerank算法简介
在这篇博客中我们讨论一下谷歌pagerank算法.这是参考的原博客连接:http://blog.jobbole.com/71431/ PageRank的Page可是认为是网页,表示网页排名,也可以认为 ...
- PageRank算法和谷歌搜索讲解
PageRank算法和谷歌搜索讲解 吴裕雄 PageRank算法实际上就是Google使用它来计算每个网页价值的算法. Google每次的搜索结果都有成百上千万甚至上亿个相关的查询网页链接.如果将所有 ...
- PageRank算法
PageRank,网页排名,又称网页级别,传说中是PageRank算法拯救了谷歌,它是根据页面之间的超链接计算的技术,作为网页排名的要素之一.它通过网络浩瀚的超链接关系来确定一个页面的等级.Googl ...
- [转]PageRank算法
原文引自: 原文引自: http://blog.csdn.net/hguisu/article/details/7996185 感谢 1. PageRank算法概述 PageRank,即网页排名,又称 ...
- PageRank算法--从原理到实现
本文将介绍PageRank算法的相关内容,具体如下: 1.算法来源 2.算法原理 3.算法证明 4.PR值计算方法 4.1 幂迭代法 4.2 特征值法 4.3 代数法 5.算法实现 5.1 基于迭代法 ...
- Machine Learning:PageRank算法
1. PageRank算法概述 PageRank,即网页排名,又称网页级别.Google左側排名或佩奇排名. 在谷歌主导互联网搜索之前, 多数搜索引擎採用的排序方法, 是以被搜索词语在 ...
- 97、PageRank算法学习
最近由于.......你懂得,需要一些搜索方面的知识,于是乎我重新复习了一下上半年读的那本书<数学之美>Dr吴军老师写的. 感觉读完这种书还是写一下比较好,因为将来说不定就会忘记了. 接下 ...
- PageRank 算法初步了解
前言 因为想做一下文本自动摘要,文本自动摘要是NLP的重要应用,搜了一下,有一种TextRank的算法,可以做文本自动摘要.其算法思想来源于Google的PageRank,所以先把PageRank给了 ...
- 基于Neo4j的个性化Pagerank算法文章推荐系统实践
新版的Neo4j图形算法库(algo)中增加了个性化Pagerank的支持,我一直想找个有意思的应用来验证一下此算法效果.最近我看Peter Lofgren的一篇论文<高效个性化Pagerank ...
随机推荐
- 方法调用时候 传入this 谁调用 传入谁
方法调用时候 传入this 谁调用 传入谁
- 【bzoj4244】邮戳拉力赛 背包dp
题目描述 IOI铁路是由N+2个站点构成的直线线路.这条线路的车站从某一端的车站开始顺次标号为0...N+1. 这条路线上行驶的电车分为上行电车和下行电车两种,上行电车沿编号增大方向行驶,下行电车沿编 ...
- CPP 替代 PIL 图片处理(缩略图生成)
python中使用PIL(Pyhton Image Library)进行图片处理,好处就是编写简单方便,但是不能很好利用机器多核的特点,于是在项目中决定使用cpp来实现图片处理. 项目中的图片处理主要 ...
- Spring Boot系列教程七:Spring boot集成MyBatis
一.创建项目 项目名称为 “springboot_mybatis_demo”,创建过程中勾选 “Web”,“MyBatis”,“MySQL”,第一次创建Maven需要下载依赖包(耐心等 ...
- Unity3D手游开发日记(4) - 适合移动平台的热浪扭曲
热浪扭曲效果的实现,分两部分,一是抓图,二是扭曲扰动.其中难点在于抓图的处理,网上的解决方案有两种,在移动平台都有很多问题,只好自己实现了一种新的方案,效果还不错. 网上方案1. 用GrabPass抓 ...
- 形态学及其他集合运算(Morphological and Other Set Operations)
摘 要:本实验主要实现形态学图像处理.主要验证图像集合的交并补运算.膨胀和腐蚀处理并利用图像集合的运算,实现形态学边界抽取算法并进行特征边界抽取.同时将膨胀和腐蚀扩展至灰度图像,编写函数实现灰度 ...
- 使用 css 的 keyframe 实现 loading 动画
效果查看:https://jsfiddle.net/rubys/je16qL5k/6/ <!DOCTYPE html> <html lang="en"> & ...
- spoj 694 705 不相同的子串的个数
http://www.spoj.com/problems/SUBST1/ SUBST1 - New Distinct Substrings #suffix-array-8 Given a string ...
- 协程-遇到I/O自动切换
参考博客:http://www.cnblogs.com/alex3714/articles/5248247.html 一.前言 Gevent 是一个第三方库,可以轻松通过gevent实现并发同步或异步 ...
- 堡垒机初识--paramiko模块
一.paramiko模块 Python的paramiko模块基于SSH用于连接远程服务器并执行相关的操作. 1.1 在windows上安装paramiko模块 测试环境: win10 , python ...