参见:
https://ww2.mathworks.cn/help/matlab/math/build-watts-strogatz-small-world-graph-model.html
生成 Watts-Strogatz 小世界图形模型
此示例演示如何构建并分析 Watts-Strogatz 小世界图形。Watts-Strogatz 模型是一个包含小世界网络属性(例如集群和平均短路径长度)的随机图形。
算法说明
创建 Watts-Strogatz 图形包含以下两个基本步骤:
执行第一步操作之后,图形将是一个完美的环形网格。因此当
时,不会重新连接任何边,并且该模型会返回一个环形网格。而如果
,则所有边都将重新连接,并且环形网格会变成随机图形。
文件 WattsStrogatz.m 对无向图实现该图算法。根据上面的算法说明,输入参数为 N、K 和 beta。
查看文件 WattsStrogatz.m。
% Copyright 2015 The MathWorks, Inc.function h = WattsStrogatz(N,K,beta)% H = WattsStrogatz(N,K,beta) returns a Watts-Strogatz model graph with N% nodes, N*K edges, mean node degree 2*K, and rewiring probability beta.%% beta = 0 is a ring lattice, and beta = 1 is a random graph.% Connect each node to its K next and previous neighbors. This constructs% indices for a ring lattice.s = repelem((1:N)',1,K);
t = s + repmat(1:K,N,1);
t = mod(t-1,N)+1;% Rewire the target node of each edge with probability betafor source=1:N
switchEdge = rand(K, 1) < beta;
newTargets = rand(N, 1);
newTargets(source) = 0;
newTargets(s(t==source)) = 0;
newTargets(t(source, ~switchEdge)) = 0;
[~, ind] = sort(newTargets, 'descend');
t(source, switchEdge) = ind(1:nnz(switchEdge));endh = graph(s,t);end
环形网格
使用 WattsStrogatz 函数构建包含 500 个节点的环形网格。beta 为 0 时,该函数会返回其节点出入度均为 2K 的环形网格。
一些随机边
通过将 beta 增大到 0.15 和 0.50,增加图形中的随机性。
随机图形
通过将 beta 增大到其最大值 1.0,生成一个完全随机的图形。这会重新连接所有边。
出入度分布
不同 Watts-Strogatz 图形中节点的出入度分布会有所不同。beta 为 0 时,这些节点的出入度均为 2K,因此出入度分布只是一个以 2K 为中心的 Dirac-delta 函数
。但是,随着 beta 的增大,出入度分布也会发生变化。
该绘图显示 beta 的非零值的出入度分布。
枢纽的形成
Watts-Strogatz 图形具有较大的集群系数,因此节点往往会形成团或较小的紧密互联的节点组。当 beta 朝其最大值 1.0 方向增加时,您会看到枢纽节点或度数相对较高的节点的数量不断增加。枢纽是其他节点之间以及图形中的团之间的常见连接。枢纽之所以存在,旨在允许形成团的同时保留平均短路径长度。
对 beta 的每个值计算平均路径长度和枢纽节点数量。就此示例而言,枢纽节点是指出入度大于或等于 55 的节点。与原始环形网格相比,这些节点的出入度全都增加了 10% 或更多。
T =
4x3 table
Beta AvgPathLength NumberOfHubs
____ _____________ ____________
0 5.48 0
0.15 2.0715 20
0.5 1.9101 85
1 1.9008 92
随着 beta 的增大,图形中的平均路径长度很快减少到其极限值。这是由于形成了紧密连接的枢纽节点,枢纽节点的数量将随着 beta 的增大而变得更多。
绘制
Watts-Strogatz 模型图,使每个节点的大小和颜色与其出入度成比例。这是使枢纽形成过程可视化的有效方式。
|