当前位置: 首页 > news >正文

如何更换网站服务商.net 网站制作

如何更换网站服务商,.net 网站制作,wordpress 左右图文排版,肇庆企业做网站系列前文#xff1a;【经典 PageRank 】01/2 PageRank的基本原理-CSDN博客 一、说明 并非所有连接都同样重要#xff01; 该算法由 Sergey 和 Lawrence 开发#xff0c;用于在 Google 搜索中对网页进行排名。基本原则是重要或值得信赖的网页更有可能链接到其他重要网页。例… 系列前文【经典 PageRank 】01/2 PageRank的基本原理-CSDN博客 一、说明 并非所有连接都同样重要 该算法由 Sergey 和 Lawrence 开发用于在 Google 搜索中对网页进行排名。基本原则是重要或值得信赖的网页更有可能链接到其他重要网页。例如来自信誉良好的网站的链接比来自不太知名的博客的链接具有更大的权重。 特征向量在理解 PageRank 算法的理论中发挥着基础作用。PageRank 和特征向量之间的联系可以在马尔可夫链或计算图及其稳态行为的背景下得到最好的理解。 二、特征向量和特征值 对于给定的方阵A和非零向量v如果向量v满足方程A*v λ*v 则它是A的特征向量。这里λ是称为特征值的标量对应于特征向量v。从概念上讲特征向量和特征向量是成对的值其中特征向量在向量空间的某个基上具有向量变换的方向特征值描述变换的大小。 2.1 网页排名 让我们将网络视为马尔可夫链其中网页是节点或状态页面之间的超链接作为方向边表示从一个页面转到另一页面的概率。当我们将此马尔可夫链表示为矩阵称为转移矩阵时PageRank 算法的目标是找到一个稳态向量其中概率总和为 1 或者没有进一步变化或收敛。查找页面排名的表达式由下式给出 其中u当前网页d阻尼因子PR( v) 页面v的页面排名N(v) 从v发出的链接数量 在 PageRank 的背景下主导特征向量对应于最大特征值的特征向量在随机矩阵的情况下为 1代表马尔可夫链的稳态分布。这种稳态分布就是我们试图计算的 PageRank 分数系统中所有网页的概率分布其中出现在页面上的概率不再随着进一步的转换而变化。 幂迭代方法涉及将向量初始 PageRank 分数重复乘以转移矩阵本质上近似于该主特征向量。随着时间的推移这个过程将会收敛得到的向量将与矩阵的主特征向量成正比从而给出网页的 PageRank 分数。 收敛背后的原因是随着每次相乘或转变主要特征值的影响会增加而其他特征值的影响会减小特别是当引入阻尼因子时。最终这导致向量与主特征向量成比例。 2.2 执行算法 将所有条目的页面排名得分矩阵初始化为 PR 1/N。表示网页- 如前所述网络被想象为有向计算图。阻尼因子- 引入来模拟随机网络冲浪者的行为因为冲浪者大部分时间都会以概率d跟踪链接但也会以(1-d)的概率移动到随机页面。迭代- 使用上述表达式计算页面排名直到它们收敛。标准化- 经过几次迭代后PageRank 值被标准化为总和为 1以检查最大特征值 1。 def PageRank(transition_matrix, d, max_iterations, conv_thres):Arguments:transition_matrix: a matrix or numpy array representing the probabilities of going from one page to anotherd: damping factormax_iterations: number of iterationsconv_thres: convergence thresholdReturn: ranks of each webpage, as columns of the transition matrix#total number of web pagesN transition_matrix.shape[0]#Intializing the transition matrix with equal probabilitiesPR np.ones(N)/Nfor _ in range(max_iterations):PR_new (1-d)/N d*np.matmul(transition_matrix,PR)#normalizing the rank scoresPR_norm np.linalg.norm(PR_new - PR, 1)#covergence constraintif PR_norm conv_thres:return PR_newPR PR_newreturn PR 现在让我们编写一个脚本将转换矩阵可视化为马尔可夫链其中网页作为状态或节点超链接作为从一个页面移动到另一页面的概率。 def markov_chain(transition_matrix):# Create a directed graph.G nx.DiGraph()# Nodes represent pages. Assume node labels are 0, 1, 2, ... for simplicity.num_nodes transition_matrix.shape[0]G.add_nodes_from(range(num_nodes))# Iterate through the transition matrix to create edges.for i in range(num_nodes):for j in range(num_nodes):if transition_matrix[i, j] 0: # Add edge if theres a non-zero transition probability.G.add_edge(i, j, weighttransition_matrix[i, j])# Visualize the graph.pos nx.spring_layout(G)nx.draw_networkx_nodes(G, pos)nx.draw_networkx_labels(G, pos)nx.draw_networkx_edge_labels(G, pos, edge_labels{(u, v): f{d[weight]:.2f} for u, v, d in G.edges(dataTrue)})nx.draw_networkx_edges(G, pos)plt.title(Markov Chain from Transition Matrix)plt.axis(off)plt.show() 三、实验代码 这是 GitHub 存储库链接ashu1069/PageRank (github.com)由 python 脚本和 Jupyter Notebook 组成。该脚本包含使用自定义输入的驱动程序代码其余部分在自述文件中进行了解释。 本质上PageRank 值代表从网络链接结构导出的转换矩阵的主要特征向量。特征向量和特征值的数学为我们提供了计算这些值的理论基础和实用方法幂迭代。 import numpy as np import networkx as nx import matplotlib.pyplot as pltdef PageRank(transition_matrix, d, max_iterations, conv_thres):Arguments:transition_matrix: a matrix or numpy array representing the probabilities of going from one page to anotherd: damping factormax_iterations: number of iterationsconv_thres: convergence thresholdReturn: ranks of each webpage, as columns of the transition matrix#total number of web pagesN transition_matrix.shape[0]#Intializing the transition matrix with equal probabilitiesPR np.ones(N)/Nfor _ in range(max_iterations):PR_new (1-d)/N d*np.matmul(transition_matrix,PR)#normalizing the rank scoresPR_norm np.linalg.norm(PR_new - PR, 1)#covergence constraintif PR_norm conv_thres:return PR_newPR PR_newreturn PR def markov_chain(transition_matrix):# Create a directed graph.G nx.DiGraph()# Nodes represent pages. Assume node labels are 0, 1, 2, ... for simplicity.num_nodes transition_matrix.shape[0]G.add_nodes_from(range(num_nodes))# Iterate through the transition matrix to create edges.for i in range(num_nodes):for j in range(num_nodes):if transition_matrix[i, j] 0: # Add edge if theres a non-zero transition probability.G.add_edge(i, j, weighttransition_matrix[i, j])# Visualize the graph.pos nx.spring_layout(G)nx.draw_networkx_nodes(G, pos)nx.draw_networkx_labels(G, pos)nx.draw_networkx_edge_labels(G, pos, edge_labels{(u, v): f{d[weight]:.2f} for u, v, d in G.edges(dataTrue)})nx.draw_networkx_edges(G, pos)plt.title(Markov Chain from Transition Matrix)plt.axis(off)plt.show()if __name__ __main__:transition_matrix np.array([[0.1,0.5,0.4],[0.2,0,0.2],[0,0.3,0.3]])d 0.85max_iterations 1000conv_thres 1e-6PR PageRank(transition_matrix, d, max_iterations, conv_thres)print(fPageRanks:{PR})markov_chain(transition_matrix) 参考资料 搜索引擎的剖析 (stanford.edu) 阿舒托什·库马尔
http://www.zqtcl.cn/news/723907/

相关文章:

  • 网站建设后压缩代码网站如何做进一步优化
  • 大型旅游网站源码 织梦襄阳网站建设楚翼网络
  • 快速搭建网站服务器做历史卷子的网站
  • 淘口令微信网站怎么做通化seo招聘
  • 帮人做传销网站违法吗深圳也放开了
  • 发布程序后网站有很多促销策略
  • 网页网站项目综合网站建设合同.doc
  • 网站建设公司黄页企业vi系统设计公司
  • 建设局网站新闻昆明个人网站建设平台
  • 清远市建设工程交易中心网站网站打开慢什么原因呢
  • 网站网址没有被百度收录做网站ddos攻击
  • 网站网站设计公司深圳建设工程交易服务网网址
  • 自学编程网站棋牌游戏在哪做网站
  • html做分页的网站以图搜图百度识图
  • 上虞区建设局网站网站建设好公司好
  • 一半都有哪些做影视外包的网站收录网站查询
  • 网站策划书撰写流程网站推广基本方法是
  • 杭州网站建设费用多少写一篇软文推广自己的学校
  • 意大利设计网站易优cms破解授权
  • 学校网站开发工程师wordpress手机博客
  • 注册网站验证码网站开发招聘需要
  • 一个销售网站的设计方案重庆广告制作加工厂
  • 宽带固定ip的怎么做网站服务器网站设计说明书整合
  • 织梦装修公司网站模板wordpress主题代码编辑教程
  • 外边做一个网站要多少钱关键词的选取原则
  • 做网站需要备案吗wordpress会员邮件通知
  • 如何在百度创建网站欧宇公司网络建设方案
  • 网站网页设计基本理论视频模板套用免费
  • 外贸人常用的网站伪静态网站
  • 优质的聊城做网站网站建设论文 网站建设论文