小书匠Graph图论

研究中经常涉及到图论的相关知识,而且常常面对某些术语时,根本不知道在说什么.前不久接触了NetworkX这个graph处理工具,发现这个工具已经解决绝大部分的图论问题(也许只是我自己认为的,没有证据证明),所以把这个工具的使用学习下,顺便学习图论的相关知识.

NetworkX本来是有官方文档的,花时间去学也是可以的,我这里把认为重要的整理出来.这些内容会分几次发布,做成一个系列使用教程.

系统环境:

linuxmint 18.3

python 3.5.2

numpy 1.14.3

matplotlib 1.5.1

networkx 2.1

全文注意事项:

1.为了方便,graph我有时候会称为,这时候不要将这个和图片混淆了.

2.代码中会频繁使用G.clear(),这是在画新的graph之前,先清空原先的graph

3.matplotlib包不能显示平行边,自循环这类的边,所以需要借助pydot包来显示,不过一般使用matplotlib来显示


目录:

1.创建一个Graph

例子:

下面涉及的graph如果不是特别需要,我将使用图1这个手动创建的graph,这个graph有双向边,有孤岛节点,有平行边,有自循环


图1 例子图

1.1导入相应包,定义graph

  1. #导入相应的包 

  2. import networkx as nx 

  3. from PIL import Image 

  4. import matplotlib.pyplot as plt 

  5. from networkx.drawing.nx_pydot import to_pydot 

  6. from matplotlib.font_manager import *  


  7. #定义自定义字体,文件名从1.b查看系统中文字体中来,这是Linux字体路径,windows系统的字体路径自查 

  8. myfont = FontProperties(fname='/usr/share/fonts/truetype/wqy/wqy-zenhei.ttc')  

  9. #解决负号'-'显示为方块的问题  

  10. matplotlib.rcParams['axes.unicode_minus']=False  


  11. #定义图的节点和边 

  12. nodes=['0','1','2','3','4','5','a','b','c'] 

  13. edges=[('0','0',1),('0','1',1),('0','5',1),('0','5',2),('1','2',3),('1','4',5),('2','1',7),('2','4',6),('a','b',0.5),('b','c',0.5),('c','a',0.5)] 


  14. #用于显示图片 

  15. def ShowGraph(G): 

  16. #使用pydot保存图片 

  17. P=to_pydot(G)  

  18. P.write_jpeg('pydot.png') 


  19. #使用matplotlib保存图片 

  20. pos=nx.shell_layout(G) 

  21. nx.draw(G,pos,with_labels=True) 

  22. plt.savefig('mat.png') 

  23. plt.close()  


  24. #将前面两张图显示 

  25. plt.subplots(figsize=(12,6)) 

  26. #plt.suptitle('Diffrent') 

  27. #载入matplotlib的图片 

  28. plt.subplot(1,2,1) 

  29. plt.title('matplotlib') 

  30. plt.imshow(Image.open('mat.png')) 

  31. #plt.axis('off') 

  32. #去掉坐标刻度 

  33. plt.xticks([]) 

  34. plt.yticks([]) 


  35. #载入pydot的图片 

  36. plt.subplot(1,2,2) 

  37. plt.title('pydot') 

  38. plt.imshow(Image.open('pydot.png')) 

  39. #plt.axis('off') 

  40. #去掉坐标刻度 

  41. plt.xticks([]) 

  42. plt.yticks([]) 


  43. #显示图片 

  44. plt.show()  

1.2有自循环的无向图

  1. #定义无向图 

  2. G = nx.Graph() 


  3. #往图添加节点和边 

  4. G.add_nodes_from(nodes) 

  5. G.add_weighted_edges_from(edges) 


  6. #显示图片 

  7. ShowGraph(G) 


有自循环的无向图

1.3有自循环的有向图

  1. #清除前面的无向图 

  2. G.clear() 


  3. #定义有向图 

  4. G = nx.DiGraph() 

  5. #添加节点和边 

  6. G.add_nodes_from(nodes) 

  7. G.add_weighted_edges_from(edges) 


  8. #显示图片 

  9. ShowGraph(G) 


有自循环的有向图

1.4有自循环和平行边的无向图

  1. #清除前面的无向图 

  2. G.clear() 


  3. #定义带平行边无向图 

  4. G = nx.MultiGraph() 

  5. #添加节点和边 

  6. G.add_nodes_from(nodes) 

  7. G.add_weighted_edges_from(edges) 


  8. #显示图片 

  9. ShowGraph(G) 


有自循环和平行边的无向图

1.5有自循环和平行边的有向图

  1. #清除前面的无向图 

  2. G.clear() 


  3. #定义带平行边有向图 

  4. G = nx.MultiDiGraph() 

  5. #添加节点和边 

  6. G.add_nodes_from(nodes) 

  7. G.add_weighted_edges_from(edges) 


  8. #显示图片 

  9. ShowGraph(G) 


有自循环和平行边的有向图

NetworkX系列教程(1)-创建graph的更多相关文章

  1. NetworkX系列教程(4)-设置graph的信息

    小书匠Graph图论 要画出美观的graph,需要对graph里面的节点,边,节点的布局都要进行设置,具体可以看官方文档:Adding attributes to graphs, nodes, and ...

  2. NetworkX系列教程(8)-Drawing Graph

    小书匠Graph图论 如果只是简单使用nx.draw,是无法定制出自己需要的graph,并且这样的graph内的点坐标的不定的,运行一次变一次,实际中一般是要求固定的位置,这就需要到布局的概念了.详细 ...

  3. NetworkX系列教程(7)-对graph进行分析

    小书匠Graph图论 graph构建完成后,对graph的连通等属性进行分析. 目录: 8.对图进行分析 8.1连通子图 8.2弱联通 8.3强连通 8.4子图 8.5条件过滤 注意:如果代码出现找不 ...

  4. NetworkX系列教程(6)-对graph进行操作

    小书匠Graph图论 graph生成后,除了有查看操作,还有移除等操作,还有其他更多操作,具体可以看这里.下面将比较graph操作前后的不同. 目录: 7.对图进行操作 7.1移除某些节点和边 7.2 ...

  5. NetworkX系列教程(5)-查看graph的信息

    小书匠Graph图论 有时候graph建好后,我们并不清除该graph内节点的,边的信息,这就需要调用函数去查看了. 目录: 6.查看Graph的信息 6.1查看graph内节点,边的 6.2查看gr ...

  6. NetworkX系列教程(3)-手动创建graph

    小书匠Graph图论 不可否认,日常中我们使用最多的还是,使用自己的数据去手动创建自己的图形,而不是使用生成器,现从给graph添加点和边入手,讲解手动创建graph. 目录: 3.给graph添加节 ...

  7. NetworkX系列教程(11)-graph和其他数据格式转换

    小书匠 Graph 图论  学过线性代数的都了解矩阵,在矩阵上的文章可做的很多,什么特征矩阵,单位矩阵等.grpah存储可以使用矩阵,比如graph的邻接矩阵,权重矩阵等,这节主要是在等到graph后 ...

  8. Spring Boot2 系列教程(二)创建 Spring Boot 项目的三种方式

    我最早是 2016 年底开始写 Spring Boot 相关的博客,当时使用的版本还是 1.4.x ,文章发表在 CSDN 上,阅读量最大的一篇有 43W+,如下图: 2017 年由于种种原因,就没有 ...

  9. NetworkX系列教程(2)-graph生成器

    小书匠Graph图论 本节主要讲解如何快速使用内置的方法生成graph,官方的文档在这里,里面包含了networkX的所有graph生成器,下面的内容只是我节选的内容,并将graph画出来而已. 声明 ...

随机推荐

  1. Spring Boot配置文件的加载顺序

    配置文件的加载顺序, 后加载的会覆盖先加载的:也就是properties配置文件的内容会替换掉.yml及.yaml文件的内容

  2. oracle_job进程相关学习测试

    Oracle cjq0进程测试 测试流程: .CJQ进程不存在 .模拟问题处理 .问题总结 一.问题现象 CJQ0进程不存在 [root@adg1 ~]# ps -ef|grep cjq root : ...

  3. Self寄宿

    static void Main(string[] args) { //Assembly.Load("WebApplication1, Version=1.0.0.0, Culture=ne ...

  4. Go 编译 && 工具

    编译和工具链 Go 的工具链非常丰富,从获取源码.编译.文档.测试.性能分析,到源码格式化.源码提示.重构工具等应有尽有 在 Go 中可以使用测试框架编写单元测试,使用统一的命令行即可测试及输出测试报 ...

  5. 在Windows上安装Redis

    微软官网源码 https://github.com/MicrosoftArchive/redis 这里介绍安装Signed binaries版本 使用Chocolatey(Windows包管理工具)安 ...

  6. 【MySQL】数据库(分库分表)中间件对比

    分区:对业务透明,分区只不过把存放数据的文件分成了许多小块,例如mysql中的一张表对应三个文件.MYD,MYI,frm. 根据一定的规则把数据文件(MYD)和索引文件(MYI)进行了分割,分区后的表 ...

  7. 关于Vue-elementUI中,给input手动赋值之后无法修改的问题解决

    方案一:在data中给input的值赋一个初始值 方案二:在给input赋值时,使用this.$set

  8. stm32和sd卡

    SD卡从容量上讲分两种:标准容量和大容量,最小的是标准容量,小于等于2G 其中的访问关系如下: SD卡分为两种模式:认证模式和传输模式,每一个模式包含着不同的状态,如下 以下主要讲其初始化过程: SD ...

  9. node.js 接口调用示例

    测试用例git地址(node.js部分):https://github.com/wuyongxian20/node-api.git 项目架构如下: controllers: 文件夹下为接口文件 log ...

  10. python 3.6 + robotFramework自动化框架 环境搭建、学习笔记

    ################################################################# #author: 陈月白 #_blogs: http://www.c ...