小书匠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. Scratch编程:躲开鲨鱼(五)

    “ 上节课的内容全部掌握了吗?反复练习了没有,编程最好的学习方法就是练习.练习.再练习.一定要记得多动手.多动脑筋哦~~” 01 — 游戏介绍 这是一款简单的小游戏,实现了用鼠标控制一条小海星在水里游 ...

  2. my linux cmd

    常用的linux命令 一.vi yy 复制当前行 u 撤销 p 粘贴 dd 删除当前行 set nu 显示行号 gg 首行 G 末行 二.用户管理相关 useradd 添加用户   (默认创建一个与用 ...

  3. GRPC代替webapi Demo。

    gRPC 是一种与语言无关的高性能远程过程调用 (RPC) 框架. gRPC 的主要优点是: 现代高性能轻量级 RPC 框架. 协定优先 API 开发,默认使用协议缓冲区,允许与语言无关的实现. 可用 ...

  4. 多个div并排不换行

    1.所有div的父元素不换行   white-space: nowrap; 2.所有div设置为行内元素  display: inline-block; 基于java记账管理系统[尚学堂·百战程序员]

  5. java保证多线程的执行顺序

    1. java多线程环境中,如何保证多个线程按指定的顺序执行呢? 1.1 通过thread的join方法保证多线程的顺序执行, wait是让主线程等待 比如一个main方法里面先后运行thread1, ...

  6. S5PV210 timer

    TCFG0, R/W, Address = 0xE250_0000 Timer Input Clock Frequency = PCLK / ( {prescaler value + 1} ) / { ...

  7. win10 下的YOLO v3 的编译与使用

    部署环境:win10 +CUDA 10.0 + vs2017 + opencv 3.4.0  代码版本是 https://github.com/AlexeyAB/darknet 1.初始准备 (1)下 ...

  8. Apache基于域名、端口、IP的虚拟主机配置(Centos 6.5)

    虚拟主机:部署多个站点,每个站点,希望用不同的域名和站点目录,或者是不同的端口,不同的ip,需要虚拟主机功能.一句话,一个http服务要配置多个站点,就需要虚拟主机. 虚拟主机分类:基于域名.基于端口 ...

  9. 【leetcode】544. Output Contest Matches

    原题 During the NBA playoffs, we always arrange the rather strong team to play with the rather weak te ...

  10. python txt文件读写(追加、覆盖)

    (1)在lucky.txt中新增内容(覆盖:每次运行都会重新写入内容) f = "lucky.txt" a =8 with open(f,"w") as fil ...