【复杂网络建模】——通过平均度和随机概率构建ER网络(Python)

🤵‍♂️ 个人主页:@Lingxw_w的个人主页

✍🏻作者简介:计算机科学与技术研究生在读
🐋 希望大家多多支持,我们一起进步!😄
如果文章对你有帮助的话,
欢迎评论 💬点赞👍🏻 收藏 📂加关注+

 目录

一、复杂网络建模

二、ER网络

三、构建ER网络方法

四、基于python构建ER网络

1、基于节点数量和链接概率 

2、基于平均度来生成

五、ER网络在现实中的实际应用


一、复杂网络建模

复杂网络建模是指对复杂网络进行描述和分析的过程。复杂网络是由大量相互连接的节点组成的网络,其中节点之间的连接关系具有一定的复杂性和非线性特征。复杂网络建模的目标是理解网络的拓扑结构、动态行为和功能特性,从而揭示网络中的模式、规律和机制。

在复杂网络建模中,常用的方法包括图论、统计物理学、机器学习和计算模拟等。以下是一些常见的复杂网络建模方法:

  1. 图论方法:复杂网络可以用图论的方式进行建模和分析。网络中的节点可以表示为图中的顶点,而节点之间的连接则表示为图中的边。通过研究网络的度分布、聚类系数、平均路径长度等图论指标,可以揭示网络的拓扑特性。

  2. 统计物理学方法:统计物理学提供了一些适用于复杂网络的模型和方法。例如,随机图模型可以用来描述节点之间的随机连接过程,小世界网络模型可以用来模拟具有高聚类系数和短平均路径长度的网络,无标度网络模型可以用来描述具有幂律度分布的节点度。

  3. 机器学习方法:机器学习方法可以用于复杂网络的预测和分类任务。例如,可以使用监督学习算法来预测节点的标签或边的存在性。此外,聚类和降维方法可以用于发现网络中的社区结构和隐藏特征。

  4. 计算模拟方法:计算模拟是通过构建数学模型和进行仿真来研究复杂网络的动态行为。例如,可以使用动力学模型来模拟节点之间的相互作用和信息传播过程,以及网络的演化过程。

综合利用以上方法,可以对复杂网络进行多层次、多角度的建模和分析,揭示网络中的规律和机制。复杂网络建模在许多领域中具有广泛的应用,包括社交网络、生物网络、交通网络、物流网络等。

二、ER网络

ER网络,全称为Erdős-Rényi网络,是一种基本的随机网络模型,由匈牙利数学家保罗·埃尔多什(Paul Erdős)和阿尔弗雷德·伦尼(Alfréd Rényi)于1959年提出。ER网络是一类具有随机连接性质的网络模型,它的构建方法基于随机概率。

在ER网络中,网络的节点数为N,任意两个节点之间以概率p相互连接,这个概率p是网络的一个参数,通常是一个介于0和1之间的值。对于每一对节点,以概率p将它们连接起来,以概率1-p不连接。这种连接方式是独立的,即每对节点的连接状态是相互独立的。

ER网络具有以下特点:

  1. 随机性:ER网络是一种随机网络模型,由于节点之间的连接是基于概率的,因此每次构建的网络都可能有不同的拓扑结构。

  2. 均匀度:在ER网络中,每个节点的度(连接数)是一个随机变量,它遵循二项分布。当节点数N较大时,度的分布逐渐接近正态分布,使得网络中的节点度相对均匀。

  3. 低聚类系数:ER网络的聚类系数(节点间的三角形连接比例)相对较低。由于节点的连接是随机的,导致网络中形成三角形结构的概率较低。

  4. 短平均路径长度:ER网络的平均路径长度通常较短。随机连接的特性使得节点之间的距离较短,信息传播的速度相对较快。

ER网络在研究复杂网络的性质和行为时起到了基础性的作用。虽然ER网络的结构相对简单,但它提供了理解随机网络的基本原理和一些特性。然而,ER网络并不能完全刻画真实世界中的复杂网络,因为它无法捕捉到一些重要的现实网络特征,如无标度性、社区结构和聚集性等。因此,研究者们在ER网络的基础上提出了许多更复杂的网络模型来更好地描述和解释现实世界中的网络。

三、构建ER网络方法

要构建ER网络,需要确定网络的节点数N和连接概率p。下面是构建ER网络的基本步骤:

  1. 初始化网络:创建一个包含N个节点的空网络。

  2. 连接节点:对于每一对节点,以概率p连接它们。可以使用随机数生成器来确定是否将两个节点连接。如果生成的随机数小于等于p,则将节点连接起来,否则不连接。

  3. 完成网络:遍历所有节点对,根据连接概率p来确定它们之间是否有连接。连接的方式可以是双向的(无向网络)或单向的(有向网络),具体取决于网络模型的定义和需求。

  4. 可选步骤:根据需要,可以进行一些后续处理。例如,可以检查网络是否是连通的(即每个节点都可以通过路径相互到达),如果不是,可以采取一些方法来增加连接,以确保网络的连通性。

需要注意的是,ER网络是一种理想化的随机网络模型,因此在构建实际网络时,节点数和连接概率的选择应该基于实际情况和研究目的。通常情况下,节点数N较大时,网络的性质更接近理论推导的结果。

此外,还有一种常用的构建ER网络的方法是使用概率矩阵。可以创建一个N × N的矩阵,其中每个元素表示节点之间连接的概率。通过对矩阵中的每个元素随机赋值,并根据概率确定连接与否,可以构建ER网络。

总结起来,构建ER网络的关键是确定节点数和连接概率,然后按照概率随机连接节点,最终形成一个随机网络模型。

四、基于python构建ER网络

1、基于节点数量和链接概率 

当使用Python构建ER网络时,可以利用NetworkX这个常用的网络分析库来实现。

import networkx as nx
import matplotlib.pyplot as plt# 定义节点数和连接概率
N = 100  # 节点数
p = 0.2  # 连接概率# 创建ER网络
er_graph = nx.erdos_renyi_graph(N, p)# 绘制网络
pos = nx.spring_layout(er_graph)  # 确定节点位置
nx.draw(er_graph, pos, with_labels=True, node_size=50)
plt.title("ER Network")
plt.show()

在上述代码中,首先导入了networkx库和matplotlib.pyplot库。然后,我们定义了节点数N和连接概率p,可以根据实际需求进行调整。

接下来,使用nx.erdos_renyi_graph(N, p)函数创建了一个ER网络,该函数接受节点数和连接概率作为参数,并返回一个ER网络的Graph对象。

最后,使用nx.draw()函数结合matplotlib.pyplot库来绘制网络图形。spring_layout函数用于确定节点的布局,with_labels=True表示在节点上显示标签,node_size定义了节点的大小。最后,通过plt.show()函数展示绘制好的ER网络图形。

运行上述代码,将生成一个具有N个节点和根据连接概率p随机连接的ER网络,并在窗口中显示绘制的网络图形。

2、基于平均度来生成

在ER网络中,连接概率p是一个决定节点之间是否连接的概率,而平均度是描述网络中每个节点平均连接数的指标。在ER网络中,连接概率p和平均度之间存在一定的关系。

具体来说,对于一个具有N个节点的ER网络,平均度〈k〉可以通过以下公式与连接概率p相关联:

〈k〉 = (N-1) * p

根据上述公式,可以通过给定平均度的值来计算连接概率p,并利用该概率构建ER网络。

import networkx as nx
import matplotlib.pyplot as plt# 定义节点数和平均度
N = 100  # 节点数
avg_degree = 4  # 平均度# 计算连接概率
p = avg_degree / (N-1)# 创建ER网络
er_graph = nx.erdos_renyi_graph(N, p)# 绘制网络
pos = nx.spring_layout(er_graph)  # 确定节点位置
nx.draw(er_graph, pos, with_labels=True, node_size=50)
plt.title("ER Network (Avg Degree = {})".format(avg_degree))
plt.show()

在上述代码中,我们首先定义了节点数N和目标平均度avg_degree。然后,通过计算连接概率p = avg_degree / (N-1) 来得到连接概率p的值。

接下来,使用nx.erdos_renyi_graph(N, p)函数创建了一个ER网络,该函数接受节点数和连接概率作为参数,并返回一个ER网络的Graph对象。

最后,使用nx.draw()函数结合matplotlib.pyplot库来绘制网络图形。其他步骤与前面的示例相同。

通过以上代码,可以根据给定的平均度值生成对应的ER网络,并进行可视化。请注意,由于连接概率是根据平均度计算得到的,实际的节点度可能会略有偏差,但整体平均度应该接近给定的目标值。

五、ER网络在现实中的实际应用

ER网络在现实中有许多实际应用,以下是其中一些常见的应用领域:

  1. 社交网络分析:ER网络可以用于建模和分析社交网络,例如在线社交媒体平台中的用户关系网络。通过研究网络的拓扑结构、信息传播和社区发现等问题,可以揭示社交网络中的模式和行为。

  2. 通信网络:ER网络可以用于模拟和分析通信网络,例如互联网、电话网络和电子邮件网络等。通过研究节点之间的连接特性和信息传输的效率,可以优化网络的设计和管理。

  3. 生物网络:ER网络可以用于建模和分析生物网络,例如蛋白质相互作用网络、神经元连接网络和食物链网络等。研究网络的结构和功能可以帮助我们理解生物系统的组织和行为。

  4. 交通网络:ER网络可以用于模拟和分析交通网络,例如道路网络和航空网络。通过研究节点之间的连接关系和交通流量,可以改进交通规划和运输管理。

  5. 网络安全:ER网络可以用于研究网络安全领域,例如分析网络攻击和传播病毒的行为。通过研究网络中的脆弱性和关键节点,可以制定有效的安全策略和防御措施。

  6. 金融网络:ER网络可以用于模拟和分析金融市场中的交易网络和风险传播网络。通过研究节点之间的连接和信息传播过程,可以揭示金融系统中的相关性和风险传播路径。

总之,ER网络作为一种基本的随机网络模型,在各种领域中都有广泛的应用。它提供了理解和分析现实世界中复杂网络的起点,并为我们揭示网络结构、行为和功能方面的一些基本原理。同时,ER网络也为更复杂的网络模型的研究奠定了基础。

 关于复杂网络建模,我前面写了很多,大家可以学习参考。

【复杂网络建模】——常用绘图软件和库_图论画图软件

【复杂网络建模】——Pytmnet进行多层网络分析与可视化

【复杂网络建模】——Python通过平均度和随机概率构建ER网络

【复杂网络建模】——通过图神经网络来建模分析复杂网络

【复杂网络建模】——Python可视化重要节点识别(PageRank算法)

【复杂网络建模】——基于Pytorch构建图注意力网络模型

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/351037.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Validation 接口入参校验

一、前言 JSR 是 Java Specification Requests 的缩写,含义为 JAVA 规范提案。 JSR 303 - Bean Validation 规范, 正是一套基于 JavaBean 参数校验的标准。 Hibernate Validator 是 JSR 303 的实现,它提供了 JSR 303 规范中所有约束(constrai…

【Java】一文搞懂生产者和消费者模型

阻塞队列的概念生产者消费者模式消息队列消息队列的作用 JDK中的阻塞队列实现阻塞队列实现生产者消费者模型 阻塞队列的概念 之前介绍过队列,是一种数据结构,先进先出FIFO。阻塞队列也满足队列的特性,不过有特殊之处: 入队元素时…

泪崩!测试面试技术面过了却挂在了——“谈谈你的职业生涯规划”

前不久,软件测试交流群里面有一个成员吐槽,说今天的面试技术已经面过了,可HR却问了她“未来的职业发展目标是什么?”然后,挂了!这个问题我们平时在交流群里都有讲过,可是这丫头比较疯&#xff0…

kml或kmz文件用什么软件打开

下载安装 bigemap GIS office软件(免费就可以) 2、 安装好下载的bigemap软件,直接将kml kmz拖到软件里面就打开了,或者左上角文件打开 选择 kml/kmz 然后选择你的文件 打开记性了。 BIGEMAP支持所有文件格式的打开和保存,如下图…

解读DXF文件

转自:http://blog.csdn.net/yingmutongxue/article/details/8226104 C语言代码读取DXF: http://www.docin.com/p-346248233.html?nb1 组码详解:http://www.doc88.com/p-21997575043.html DXF文件就是以文档的格式描述图形数据的。可以用写…

GS2972(3G-SDI)视频输出驱动调试

GS2972视频输出调试 GS2972的硬件初始化GS2972的驱动时序GS2972的驱动RTL代码GS2972输出彩条GS2972驱动易出bug GS2972的硬件初始化 GS2972是HD-SDI/3G-SDI视频、音频串化器。其使用非常简单,但是要想把该芯片驱动起来,真心不容易。需要了解相关视频标准…

如何在Moonbeam设置多重签名钱包,加固资产安全

Moonbeam Safe是以太坊上Safe(先前名为Gnosis Safe)的分叉。Safe于2018年正式推出,并发展成为了以太坊上知名的去中心化托管协议和集体资产管理平台。 Moonbeam Safe可用于创建多重签名Safe钱包,通过配置一个多签(mul…

【Protobuf速成指南】Win/Centos7下Protobuf安装教程

文章目录 安装教程一、Windows1.1 下载编译器1.2 配置PATH1.3 其他依赖项 二、Centos72.1 安装必要的工具2.2 下载安装包2.3 安装 安装教程 以版本为V21.11为例说明 一、Windows 1.1 下载编译器 下载地址:链接,一直往下翻找到 V21.11版本 win用户根据…

去除迅雷极速版 提示升级的广告

转载于:https://www.cnblogs.com/x-huihui/p/10926954.html

迅雷精简版 4.0.0 Mac中文版

迅雷精简版是一款非常实用的下载工具,体积轻巧但是下载速度却依然很快,采用与浏览器结合的方式,让用户在享受极速下载模式的同时也能流畅上网,系统性能依然稳定,而且迅雷精简版没有广告,给用户更好的上网体…

迅雷精简版 for Mac 去除多余无用功能

推一款非常给力、速度又快的专业下载工具mac迅雷精简版,普通的非VIP迅雷软件往往会出现一些下载限速,体验上相对并不是很好,而迅雷极速精简版则更好的解决了这个问题,其界面清爽简约,无广告,下载速度快&…

[Android] 安卓迅雷带云盘内测版7.0 简洁 无广告 官方版

迅雷内测版本 界面 简洁 无广告 带云盘功能 我也不多说 大家都知道迅雷APP 版本德性 全是广告 直接上图 跟链接 对于我说 内测版本 属实香 看不到一点广告 下载地址: https://n802.com/file/349707-458153240 http://www.yimuhe.com/file-4770885.html http://www.369pan.c…

2015 年一月联考逻辑真题

2015 年一月联考逻辑真题 真题(2015-26) 26.晴朗的夜晚我们可以看到满天星斗,其中有些是自身发光的恒星,有些是自身不发光但可以反射附近恒星光的行星。恒星尽管遥远,但是有些可以被现有的光学望远镜“看到”。和恒星不…

python使用requests+excel进行接口自动化测试

在当今的互联网时代中,接口自动化测试越来越成为软件测试的重要组成部分。Python是一种简单易学,高效且可扩展的语言,自然而然地成为了开发人员的首选开发语言。而requests和xlwt这两个常用的Python标准库,能够帮助我们轻松地开发…

navicat与SQLyog的区别

在之前的学习中由于先学的SQL Server,后来才学的MySQL,导致我刚学习的时候冥冥之中感觉到那有点不对劲,但是又说不出来。通过进行深入的学习解除到了Navicat Premium和SQLyog这两个工具,才让我明白了MySQL与之前学习的内容是有所出…

usb2.0-crw出现黄色叹号

最近点开设备管理器发现了许多黄色感叹号: 解决方案: 进入电脑官网,我的是DELL,搜索"驱动与下载dell",输入自己的电脑型号,在手动搜索的模块里找主板芯片组,下载并安装。

postgrsql 增加字段

alter table 表名 add 字段名 数据类型; 不支持指定位置增加列,增加的列在末尾。 实例:alter table crw_it.ncs_ccs_stmt_zdhk add stmt_no varchar; crw_it是模式名(schema)

STM32单片机蓝牙APP语音识别取暖器GSM短信超温报警

实践制作DIY- GC0141-蓝牙APP语音识别取暖器 基于STM32单片机设计---蓝牙APP语音识别取暖器 二、功能介绍: 电路:STM32F103C最小系统DS18B20温度传感器 多个按键 LCD1602显示器 1个串口语音识别模块1个5V 加热片 模拟加热蜂鸣器SIM800 GSM短信模块 HC0…

ubuntu下依靠guvcview使用摄像头

1.检验系统是否可以检测到设备 $ lsusb Bus 001 Device 040: ID 046d:0825 Logitech, Inc. Webcam C270 如果没有相关的信息说明系统的驱动未安装。 2.检验摄像头的端口 ls -la /dev/vid* crw-rw---- 1 root video 81, 0 Feb 12 2016 /dev/video0 crw-rw---- 1 root vid…

降本增效,StarRocks 在同程旅行的实践

作者:周涛 同程旅行数据中心大数据研发工程师 同程旅行是中国在线旅游行业的创新者和市场领导者。作为一家一站式平台,同程旅行致力于满足用户旅游需求,秉持 "让旅行更简单、更快乐" 的使命,主要通过包括微信小程序、AP…