社区划分-PageRank算法的解析与Python实现

一、什么是pagerank

PageRank的Page可是认为是网页,表示网页排名,也可以认为是Larry Page(google 产品经理),因为他是这个算法的发明者之一,还是google CEO(^_^)。PageRank算法计算每一个网页的PageRank值,然后根据这个值的大小对网页的重要性进行排序。它的思想是模拟一个悠闲的上网者,上网者首先随机选择一个网页打开,然后在这个网页上呆了几分钟后,跳转到该网页所指向的链接,这样无所事事、漫无目的地在网页上跳来跳去,PageRank就是估计这个悠闲的上网者分布在各个网页上的概率。

二、最简单pagerank模型

互联网中的网页可以看出是一个有向图,其中网页是结点,如果网页A有链接到网页B,则存在一条有向边A->B,下面是一个简单的示例:


这个例子中只有四个网页,如果当前在A网页,那么悠闲的上网者将会各以1/3的概率跳转到B、C、D,这里的3表示A有3条出链,如果一个网页有k条出链,那么跳转任意一个出链上的概率是1/k,同理D到B、C的概率各为1/2,而B到C的概率为0。一般用转移矩阵表示上网者的跳转概率,如果用n表示网页的数目,则转移矩阵M是一个n*n的方阵;如果网页j有k个出链,那么对每一个出链指向的网页i,有M[i][j]=1/k,而其他网页的M[i][j]=0;上面示例图对应的转移矩阵如下:

初试时,假设上网者在每一个网页的概率都是相等的,即1/n,于是初试的概率分布就是一个所有值都为1/n的n维列向量V0,用V0去右乘转移矩阵M,就得到了第一步之后上网者的概率分布向量MV0,(nXn)*(nX1)依然得到一个nX1的矩阵。下面是V1的计算过程:

注意矩阵M中M[i][j]不为0表示用一个链接从j指向i,M的第一行乘以V0,表示累加所有网页到网页A的概率即得到9/24。得到了V1后,再用V1去右乘M得到V2,一直下去,最终V会收敛,即Vn=MV(n-1),上面的图示例,不断的迭代,最终V=[3/9,2/9,2/9,2/9]‘:

 

三、终止点问题

 

上述上网者的行为是一个马尔科夫过程的实例,要满足收敛性,需要具备一个条件:

  • 图是强连通的,即从任意网页可以到达其他任意网页:

互联网上的网页不满足强连通的特性,因为有一些网页不指向任何网页,如果按照上面的计算,上网者到达这样的网页后便走投无路、四顾茫然,导致前面累计得到的转移概率被清零,这样下去,最终的得到的概率分布向量所有元素几乎都为0。假设我们把上面图中C到A的链接丢掉,C变成了一个终止点,得到下面这个图:

 


对应的转移矩阵为:

连续迭代下去,最终所有元素都为0:

 

四、陷阱问题

另外一个问题就是陷阱问题,即有些网页不存在指向其他网页的链接,但存在指向自己的链接。比如下面这个图:

 


上网者跑到C网页后,就像跳进了陷阱,陷入了漩涡,再也不能从C中出来,将最终导致概率分布值全部转移到C上来,这使得其他网页的概率分布值为0,从而整个网页排名就失去了意义。如果按照上面图对应的转移矩阵为:

不断的迭代下去,就变成了这样:

 

五、解决终止点问题和陷阱问题

上面过程,我们忽略了一个问题,那就是上网者是一个悠闲的上网者,而不是一个愚蠢的上网者,我们的上网者是聪明而悠闲,他悠闲,漫无目的,总是随机的选择网页,他聪明,在走到一个终结网页或者一个陷阱网页(比如两个示例中的C),不会傻傻的干着急,他会在浏览器的地址随机输入一个地址,当然这个地址可能又是原来的网页,但这里给了他一个逃离的机会,让他离开这万丈深渊。模拟聪明而又悠闲的上网者,对算法进行改进,每一步,上网者可能都不想看当前网页了,不看当前网页也就不会点击上面的连接,而上悄悄地在地址栏输入另外一个地址,而在地址栏输入而跳转到各个网页的概率是1/n。假设上网者每一步查看当前网页的概率为a,那么他从浏览器地址栏跳转的概率为(1-a),于是原来的迭代公式转化为:

 


现在我们来计算带陷阱的网页图的概率分布:

重复迭代下去,得到:


六、用Python实现Page Rank算法

 

 

 

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):   #构造转移矩阵
    b = transpose(a)  #b为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] / (b[j].sum())  #完成初始化分配
    #print c,"\n===================================================="
    return c

def firstPr(c):   #pr值得初始化
    pr = zeros((c.shape[0],1),dtype = float)  #构造一个存放pr值得矩阵
    for i in range(c.shape[0]):
        pr[i] = float(1)/c.shape[0]
    #print pr,"\n==================================================="
    return pr
    
def pageRank(p,m,v):  #计算pageRank值
    while((v == p*dot(m,v) + (1-p)*v).all()==False):  #判断pr矩阵是否收敛,(v == p*dot(m,v) + (1-p)*v).all()判断前后的pr矩阵是否相等,若相等则停止循环
        #print v
        v = p*dot(m,v) + (1-p)*v
        #print (v == p*dot(m,v) + (1-p)*v).all()
    return v

if __name__=="__main__":
    M = graphMove(a)
    pr = firstPr(M)
    p = 0.8           #引入浏览当前网页的概率为p,假设p=0.8
    print pageRank(p,M,pr)  # 计算pr值  

 


搜索与推荐Wiki

扫一扫 关注微信公众号!号主 专注于搜索和推荐系统,尝试使用算法去更好的服务于用户,包括但不局限于机器学习,深度学习,强化学习,自然语言理解,知识图谱,还不定时分享技术,资料,思考等文章!


                             【技术服务】,详情点击查看:https://mp.weixin.qq.com/s/PtX9ukKRBmazAWARprGIAg


外包服务

  • 15
    点赞
  • 71
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: PageRank算法是一种用于评估网页重要性的算法,它是由Google公司的创始人之一Larry Page提出的。在Python实现PageRank算法,可以使用网络分析库NetworkX来构建图形,并使用PageRank函数来计算每个节点的PageRank值。具体实现步骤如下: 1. 导入NetworkX库 ```python import networkx as nx ``` 2. 构建图形 ```python G = nx.DiGraph() # 创建有向图 G.add_edges_from([(1, 2), (1, 3), (2, 1), (3, 2), (3, 4), (4, 3)]) # 添加边 ``` 3. 计算PageRank值 ```python pr = nx.pagerank(G, alpha=.85) # 计算PageRank值 print(pr) # 输出每个节点的PageRank值 ``` 其中,alpha参数表示阻尼因子,通常取值为.85。输出结果为一个字典,键为节点编号,值为对应的PageRank值。 以上就是PageRank算法Python中的实现方法。 ### 回答2: Pagerank算法是一种被广泛应用在搜索引擎中的算法,它通过计算Web页面之间的链接关系和权重来确定页面的排名。Python是一种流行的编程语言,有许多开源工具可以用来实现Pagerank算法。 在Python实现Pagerank算法时,我们需要使用一些关键库。其中最重要的是网络X(NetworkX)库,它提供了一系列用于构建、分析和可视化复杂网络的函数和类。此外,NumPy和SciPy这两个数学库也将被用来优化算法。在这个过程中,我们需要用到一些数学公式,包括向量的转置、矩阵乘法和向量归一化等。 下面是Pagerank算法Python实现的大致思路: 1. 首先,定义一个图的数据结构,用来表示Web页面之间的链接关系。 2. 然后,使用网络X库的pagerank函数计算每个页面的初始排名。pagerank函数将返回一个字典,包含每个页面和对应的排名值。 3. 接下来,我们需要使用一些数学公式和矩阵操作,如向量的转置、矩阵乘法和向量归一化等,计算每个页面的更新排名。 4. 最后,反复迭代以上步骤,直到页面的排名不再变化或者达到最大迭代次数。 下面是Pagerank算法Python实现的简化代码: ``` import networkx as nx import numpy as np # 构建图的数据结构 G = nx.DiGraph() G.add_edges_from([(1,2), (2,3), (3,2), (3,1)]) # 计算每个页面的初始排名 pr = nx.pagerank(G, alpha=0.85) print(pr) # 定义矩阵A和B,并初始化页面排名向量 N = len(G.nodes()) A = nx.to_numpy_matrix(G) B = np.ones((N,N)) / N x = np.ones((N,1)) / N # 反复迭代计算每个页面的更新排名 for i in range(100): x = 0.85 * np.dot(A,x) + 0.15 * np.dot(B,x) x /= np.linalg.norm(x,1) # 输出结果 print(x) ``` 在以上代码中,我们首先构建了一个有向图,用来表示Web页面之间的链接关系。然后使用networkx库的pagerank函数计算每个页面的初始排名,这里alpha参数表示阻尼系数,通常设置为0.85。接着定义矩阵A和B,分别表示页面间的链接关系和随机跳转概率。在每次迭代中,使用矩阵乘法计算每个页面的更新排名,并归一化处理。最后输出结果,表示每个页面的最终排名。 需要注意的是,Pagerank算法中,如果存在一些孤立的节点,也就是没有出度的节点,就需要先对这些节点进行处理,将它们与所有的节点都建立链接关系。另外,对于大规模的网络,Pagerank算法需要进行优化,采用稀疏矩阵存储和迭代加速等技术,以提高计算效率。 ### 回答3: Pagerank算法是一种被广泛用于搜索引擎中的算法,用于计算网页的重要性和排名。在Python中,可以使用网络科学库NetworkX来实现Pagerank算法。 首先,我们需要安装NetworkX库。可以在命令行中使用以下命令来安装: ``` pip install networkx ``` 接下来,我们需要导入NetworkX库: ```python import networkx as nx ``` 然后,我们可以使用nx.DiGraph()来创建一个有向图(DiGraph),并使用add_edge()方法来添加边: ```python G = nx.DiGraph() G.add_edge('A', 'B') G.add_edge('A', 'C') G.add_edge('B', 'C') G.add_edge('C', 'A') ``` 以上代码创建了一个由四个节点(A、B、C、D)和四条有向边组成的有向图。接下来,我们可以使用nx.pagerank()方法来计算每个节点的Pagerank值: ```python pagerank = nx.pagerank(G) ``` pagerank是一个字典,其中键是节点名称,值是该节点的Pagerank值。我们可以使用以下代码输出每个节点的Pagerank值: ```python for node in pagerank: print(node, pagerank[node]) ``` 以上代码将输出每个节点的名称和对应的Pagerank值。可以使用这些值来对网页进行排序和排名。 Pagerank算法是一种基本的搜索引擎算法,具有广泛的应用价值。Python提供了简单、高效的实现方法,可以方便地使用Pagerank算法进行网页排名和排序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值