Python复杂网络分析库networkx 看这一篇就够了

文章目录

  • 1 基础知识
    • 1.1 简介
    • 1.2 Graph
      • 添加节点
      • 访问节点
      • 删除节点
      • 添加边
      • 访问边
      • 遍历边
      • 生成小世界网络
      • 生成规则网络
  • 另一种规则图
  • ER随即图
  • BA无标度网络

喜欢的话请关注我们的微信公众号~《 你好世界炼丹师》。

  • 公众号主要讲统计学,数据科学,机器学习,深度学习,以及一些参加Kaggle竞赛的经验。
  • 公众号内容建议作为课后的一些相关知识的补充,饭后甜点。
  • 此外,为了不过多打扰,公众号每周推送一次,每次4~6篇精选文章。

微信搜索公众号:你好世界炼丹师。期待您的关注。


1 基础知识

1.1 简介

networkx在2002年5月产生,是一个用Python语言开发的图论与复杂网络建模工具,内置了常用的图与复杂网络分析算法,可以方便的进行复杂网络数据分析、仿真建模等工作。

networkx支持创建简单无向图、有向图和多重图;内置许多标准的图论算法,节点可为任意数据;支持任意的边值维度,功能丰富,简单易用。

  • 可以生成多种随即网络,经典网络等

1.2 Graph

  • Graph是用点和线来刻画离散事物集合中的每对事物间以某种方式相联系的数学模型。
  • 根据Graph的定义,一个Graph包含一个节点集合和一个边集。
  • Graph:指无向图(undirected Graph),即忽略了两节点间边的方向。
  • DiGraph:指有向图(directed Graph),即考虑了边的有向性。
  • MultiGraph:指多重无向图,即两个结点之间的边数多于一条,又允许顶点通过同一条边和自己关联。
  • MultiDiGraph:多重图的有向版本。

添加节点

import networkx as nx
import matplotlib.pyplot as plt
G = nx.Graph()
G.add_node('a')
G.add_node_from(['b','c','d','e'])
nx.draw(G,with_labels=True)
plt.show()

运行结果:
Python复杂网络分析库networkx 看这一篇就够了_第1张图片
因为我们只在图中增加了几个点,没有边

访问节点

print('图中所有的节点', G.nodes())
print('图中节点的个数', G.number_of_nodes())

运行结果:
Python复杂网络分析库networkx 看这一篇就够了_第2张图片

删除节点

G.remove_node(1)    #删除指定节点
G.remove_nodes_from(['b','c','d','e'])    #删除集合中的节点

添加边

G.add_edge('a','b')
G.add_edges_from([('a','c'),('a','d'),('a','e')])

运行结果:
Python复杂网络分析库networkx 看这一篇就够了_第3张图片

访问边

print('图中所有的边', F.edges())
print('图中边的个数', F.number_of_edges()) 

Python复杂网络分析库networkx 看这一篇就够了_第4张图片

遍历边

for u,v,d in G.edges(data = 'weight'):
    print((u,v,d))

Python复杂网络分析库networkx 看这一篇就够了_第5张图片
无权重的

for n, nbrs in G.adjacency():
    for nbr, eattr in nbrs.items():
        print('({},{})'.format(n,nbr))

Python复杂网络分析库networkx 看这一篇就够了_第6张图片
有权重的

for n, nbrs in G.adjacency():
    for nbr, eattr in nbrs.items():
    	data = eattr['weight']
        print('({},{},{})'.format(n,nbr,data))

生成小世界网络

参考小世界网络和复杂网络+python代码实现

import networkx as ne #导入建网络模型包,命名ne
import matplotlib.pyplot as plt #导入科学绘图包,命名mp
#WS network graphy
print('请输入网络节点总数NETWORK_SIZE:')
NETWORK_SIZE=int(input())
print('请输入规则网络要连的邻接个数k:')
k=int(input())
print('请输入重连概率p:')
p=float(input())
ws=ne.watts_strogatz_graph(NETWORK_SIZE,k,p)
ps=ne.circular_layout(ws)#布置框架
ne.draw(ws,ps,with_labels=False,node_size=30)
plt.show()

Python复杂网络分析库networkx 看这一篇就够了_第7张图片

生成规则网络

如果把重练概率改为0,则为规则网络
代码同上
Python复杂网络分析库networkx 看这一篇就够了_第8张图片

另一种规则图

生成含有20个节点,每个节点包含3个邻居的规则图

import networkx as nx
import matplotlib.pyplot as plt
RG = nx.random_graphs.random_regular_graph(3,20)
# pos = nx.spectral_layout(RG)
pos = nx.circular_layout(RG)
nx.draw(RG,pos,with_labels=False,node_size = 30)
plt.show()

ER随即图

以概率p生成N个节点中的每一对节点

import networkx as nx
import matplotlib.pyplot as plt
ER = nx.random_graphs.erdos_renyi_graph(20,0.2)
pos = nx.shell_layout(ER)
nx.draw(ER,pos,with_labels = False,node_size = 30)
plt.show()

BA无标度网络

涩会给你成n个节点,每次加入m条边的BA无标度网络

import networkx as nx
import matplotlib.pyplot as plt
BA = nx.random_graphs.barabasi_albert_graph(20,1)
pos = nx.spring_layout(BA)
nx.draw(BA,pos,with_labels=False,node_size=30)
plt.show()

Python复杂网络分析库networkx 看这一篇就够了_第9张图片

你可能感兴趣的:(norm,emergency规范)