如何生成matlab模型的图片,生成 Watts-Strogatz 小世界图形模型

算法说明

创建 Watts-Strogatz 图形包含以下两个基本步骤:

创建一个环形网格,其中包含 b0885b6aeac7949b1d973ce699d5ef82.png 个平均出入度为 85d39955f71141cae1ab827ba6d7ba92.png 的节点。每个节点都与任一侧的 cb0213ba3f0b3c4e1b57fcb365584159.png 个最近邻点相连。

对于图中的每条边,重新连接概率为 aeecd4eee80d1e2e6048943de17c596a.png 的目标节点。重新连接的边不能是重复或自环的。

执行第一步操作之后,图形将是一个完美的环形网格。因此当 492a8ebaf38054b47fa9fc15d04e64c8.png 时,不会重新连接任何边,并且该模型会返回一个环形网格。而如果 90ab36d0a5ff4d7308ddcdf9deae6dac.png,则所有边都将重新连接,并且环形网格会变成随机图形。

文件 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 beta

for 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));

end

h = graph(s,t);

end

环形网格

使用 WattsStrogatz 函数构建包含 500 个节点的环形网格。beta 为 0 时,该函数会返回其节点出入度均为 2K 的环形网格。

h = WattsStrogatz(500,25,0);

plot(h,'NodeColor','k','Layout','circle');

title('Watts-Strogatz Graph with $N = 500$ nodes, $K = 25$, and $\beta = 0$', ...

'Interpreter','latex')

77da6f9a1cffa950759d0988258a69d8.png

一些随机边

通过将 beta 增大到 0.15 和 0.50,增加图形中的随机性。

h2 = WattsStrogatz(500,25,0.15);

plot(h2,'NodeColor','k','EdgeAlpha',0.1);

title('Watts-Strogatz Graph with $N = 500$ nodes, $K = 25$, and $\beta = 0.15$', ...

'Interpreter','latex')

59cb37caa894bb65c78cc0636035c50f.png

h3 = WattsStrogatz(500,25,0.50);

plot(h3,'NodeColor','k','EdgeAlpha',0.1);

title('Watts-Strogatz Graph with $N = 500$ nodes, $K = 25$, and $\beta = 0.50$', ...

'Interpreter','latex')

3c105133c5a0d91fe45a9d6c8563205c.png

随机图形

通过将 beta 增大到其最大值 1.0,生成一个完全随机的图形。这会重新连接所有边。

h4 = WattsStrogatz(500,25,1);

plot(h4,'NodeColor','k','EdgeAlpha',0.1);

title('Watts-Strogatz Graph with $N = 500$ nodes, $K = 25$, and $\beta = 1$', ...

'Interpreter','latex')

3372b3efa17fb562dc07db4363f16f55.png

出入度分布

不同 Watts-Strogatz 图形中节点的出入度分布会有所不同。beta 为 0 时,这些节点的出入度均为 2K,因此出入度分布只是一个以 2K 为中心的 Dirac-delta 函数 84457bed0172509e1fe20177e3efa644.png。但是,随着 beta 的增大,出入度分布也会发生变化。

该绘图显示 beta 的非零值的出入度分布。

histogram(degree(h2),'BinMethod','integers','FaceAlpha',0.9);

hold on

histogram(degree(h3),'BinMethod','integers','FaceAlpha',0.9);

histogram(degree(h4),'BinMethod','integers','FaceAlpha',0.8);

hold off

title('Node degree distributions for Watts-Strogatz Model Graphs')

xlabel('Degree of node')

ylabel('Number of nodes')

legend('\beta = 1.0','\beta = 0.50','\beta = 0.15','Location','NorthWest')

f5991e7d7261b1b471c45f74a7075ebc.png

枢纽的形成

Watts-Strogatz 图形具有较大的集群系数,因此节点往往会形成团或较小的紧密互联的节点组。当 beta 朝其最大值 1.0 方向增加时,您会看到枢纽节点或度数相对较高的节点的数量不断增加。枢纽是其他节点之间以及图形中的团之间的常见连接。枢纽之所以存在,旨在允许形成团的同时保留平均短路径长度。

对 beta 的每个值计算平均路径长度和枢纽节点数量。就此示例而言,枢纽节点是指出入度大于或等于 55 的节点。与原始环形网格相比,这些节点的出入度全都增加了 10% 或更多。

n = 55;

d = [mean(mean(distances(h))), nnz(degree(h)>=n); ...

mean(mean(distances(h2))), nnz(degree(h2)>=n); ...

mean(mean(distances(h3))), nnz(degree(h3)>=n);

mean(mean(distances(h4))), nnz(degree(h4)>=n)];

T = table([0 0.15 0.50 1]', d(:,1), d(:,2),...

'VariableNames',{'Beta','AvgPathLength','NumberOfHubs'})

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 的增大而变得更多。

绘制 95bb2d68f483e4f2588e23d7464761a3.png Watts-Strogatz 模型图,使每个节点的大小和颜色与其出入度成比例。这是使枢纽形成过程可视化的有效方式。

colormap hsv

deg = degree(h2);

nSizes = 2*sqrt(deg-min(deg)+0.2);

nColors = deg;

plot(h2,'MarkerSize',nSizes,'NodeCData',nColors,'EdgeAlpha',0.1)

title('Watts-Strogatz Graph with $N = 500$ nodes, $K = 25$, and $\beta = 0.15$', ...

'Interpreter','latex')

colorbar

52cd3ef7d078267c0931d92bbc099465.png

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Watts-Strogatz世界网络是一种在网络科学领域使用广泛的模型。它由基于图论的数学模型提出,旨在描述现实世界中的社交网络、互联网和蛋白质相互作用网络等系统。该模型能够模拟一种介于规则网络和随机网络之间的网络结构。 在Python编程语言中,我们可以使用NetworkX库来实现Watts-Strogatz世界网络的构建和分析。NetworkX是一个开源的Python软件包,专注于复杂网络的创建、操作和研究。 首先,我们需要导入NetworkX库: ```python import networkx as nx ``` 接下来,我们可以使用nx.watts_strogatz_graph函数来生成Watts-Strogatz世界网络。该函数的输入参数包括节点数量n、每个节点的邻居数量k、重连概率p等。例如,我们可以创建一个包含100个节点、每个节点有6个邻居、重连概率为0.1的小世界网络: ```python n = 100 k = 6 p = 0.1 ws_graph = nx.watts_strogatz_graph(n, k, p) ``` 通过调用nx.draw函数,我们可以将这个网络可视化出来: ```python nx.draw(ws_graph, with_labels=True) ``` 此外,我们还可以利用NetworkX库提供的各种函数来分析Watts-Strogatz世界网络的拓扑性质,比如节点度分布、聚集系数、平均最短路径长度等。例如,我们可以计算该网络的平均最短路径长度: ```python avg_shortest_path = nx.average_shortest_path_length(ws_graph) ``` 总结来说,通过Python编程语言中的NetworkX库,我们可以方便地构建和分析Watts-Strogatz世界网络。这种网络模型有助于我们理解真实世界中复杂网络的形成和演化过程。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值