小书匠Graph图论

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

声明,文中重复使用了以下代码块 ,现在统一注释在这里:

  1. plt.subplot(221) #生成2*2的组图,并且当前子图在2*2矩阵的第一个位置.第二个位置是222 

  2. plt.title('complete_graph') #子图的标题 

  3. nx.draw(G, with_labels=True, font_weight='bold') #将graph画出来 

  4. plt.axis('on') #需要坐标轴,以便框住graph 

  5. plt.xticks([]) #横坐标不需要刻度 

  6. plt.yticks([]) #纵坐标不需要刻度 

目录:


注意:如果代码出现找不库,请返回第一个教程,把库文件导入.

2.生成graph

2.1小图图集的生成器

  1. #graph_atlas的图已经被定义,只需要按标号取出来就可以,下面将前10个取出来 

  2. plt.subplots(2,5,figsize=(15,6)) 

  3. for ind in range(10): 

  4. G.clear() 


  5. G=nx.graph_atlas(ind) 

  6. plt.subplot(2,5,ind+1) 

  7. nx.draw(G,with_labels=True) 


  8. #下面是设置图片 

  9. plt.axis('on') 

  10. plt.title('graph_atlas_%s'%ind) 

  11. plt.xticks([]) 

  12. plt.yticks([]) 

  13. plt.show() 

  14. plt.close() 


小图图集的生成器

2.2调用函数生成经典的graph

  1. plt.subplots(2,2,figsize=(15,6)) 


  2. K_5 = nx.complete_graph(5) 

  3. plt.subplot(221) 

  4. plt.title('complete_graph') 

  5. nx.draw(K_5, with_labels=True, font_weight='bold') 

  6. plt.axis('on') 

  7. plt.xticks([]) 

  8. plt.yticks([]) 


  9. K_3_5 = nx.complete_bipartite_graph(3, 5) 

  10. plt.subplot(222) 

  11. plt.title('complete_bipartite_graph') 

  12. nx.draw(K_3_5, with_labels=True, font_weight='bold') 

  13. plt.axis('on') 

  14. plt.xticks([]) 

  15. plt.yticks([]) 


  16. barbell = nx.barbell_graph(10, 10) 

  17. plt.subplot(223) 

  18. plt.title('barbell_graph') 

  19. nx.draw(barbell, with_labels=True, font_weight='bold') 

  20. plt.axis('on') 

  21. plt.xticks([]) 

  22. plt.yticks([]) 


  23. lollipop = nx.lollipop_graph(10, 20) 

  24. plt.subplot(224) 

  25. plt.title('lollipop_graph') 

  26. nx.draw(lollipop, with_labels=True, font_weight='bold') 

  27. plt.axis('on') 

  28. plt.xticks([]) 

  29. plt.yticks([]) 


  30. plt.show() 


经典的graph

2.3格子graph

  1. G.clear() 


  2. plt.subplots(2,3,figsize=(15,6)) 

  3. #二维网格图 

  4. G=nx.grid_2d_graph(2,3) 

  5. plt.subplot(2,3,1) 

  6. nx.draw(G,with_labels=True) 

  7. plt.title('grid_2d_graph') 

  8. plt.axis('on') 

  9. plt.xticks([]) 

  10. plt.yticks([]) 


  11. #n维网格图 

  12. grid_graph = nx.grid_graph(dim=[1, 3, 4]) 

  13. plt.subplot(2,3,2) 

  14. nx.draw(grid_graph,with_labels=True) 

  15. plt.title('grid_graph') 

  16. plt.axis('on') 

  17. plt.xticks([]) 

  18. plt.yticks([]) 


  19. #m×n的六角形格子图。 

  20. G=nx.hexagonal_lattice_graph(2,3) 

  21. plt.subplot(2,3,3) 

  22. nx.draw(G,with_labels=True) 

  23. plt.title('hexagonal_lattice_graph') 

  24. plt.axis('on') 

  25. plt.xticks([]) 

  26. plt.yticks([]) 


  27. #n维超立方体图形。 

  28. G=nx.hypercube_graph(3) 

  29. plt.subplot(2,3,4) 

  30. nx.draw(G,with_labels=True) 

  31. plt.title('hypercube_graph') 

  32. plt.axis('on') 

  33. plt.xticks([]) 

  34. plt.yticks([]) 


  35. #三角格子图 

  36. G=nx.triangular_lattice_graph(1,3) 

  37. plt.subplot(2,3,5) 

  38. nx.draw(G,with_labels=True) 

  39. plt.title('hypercube_graph') 

  40. plt.axis('on') 

  41. plt.xticks([]) 

  42. plt.yticks([]) 


  43. plt.show() 


格子graph

2.4各种已经被命名的小graph

  1. plt.subplots(2,2,figsize=(15,6)) 


  2. petersen = nx.petersen_graph() 

  3. plt.subplot(221) 

  4. plt.title('petersen_graph') 

  5. nx.draw(petersen, with_labels=True, font_weight='bold') 

  6. plt.axis('on') 

  7. plt.xticks([]) 

  8. plt.yticks([]) 


  9. tutte = nx.tutte_graph() 

  10. plt.subplot(222) 

  11. plt.title('tutte_graph') 

  12. nx.draw(tutte, with_labels=True, font_weight='bold') 

  13. plt.axis('on') 

  14. plt.xticks([]) 

  15. plt.yticks([]) 


  16. maze = nx.sedgewick_maze_graph() 

  17. plt.subplot(223) 

  18. plt.title('sedgewick_maze_graph') 

  19. nx.draw(maze, with_labels=True, font_weight='bold') 

  20. plt.axis('on') 

  21. plt.xticks([]) 

  22. plt.yticks([]) 


  23. tet = nx.tetrahedral_graph() 

  24. plt.subplot(224) 

  25. plt.title('tetrahedral_graph') 

  26. nx.draw(tet, with_labels=True, font_weight='bold') 

  27. plt.axis('on') 

  28. plt.xticks([]) 

  29. plt.yticks([]) 


  30. plt.show() 


已经被命名的小graph

2.5使用随机graph生成器

  1. plt.subplots(2,2,figsize=(15,6)) 


  2. er = nx.erdos_renyi_graph(10, 0.15) 

  3. plt.subplot(221) 

  4. plt.title('erdos_renyi_graph') 

  5. nx.draw(er, with_labels=True, font_weight='bold') 

  6. plt.axis('on') 

  7. plt.xticks([]) 

  8. plt.yticks([]) 


  9. ws = nx.watts_strogatz_graph(30, 3, 0.1) 

  10. plt.subplot(222) 

  11. plt.title('watts_strogatz_graph') 

  12. nx.draw(ws, with_labels=True, font_weight='bold') 

  13. plt.axis('on') 

  14. plt.xticks([]) 

  15. plt.yticks([]) 


  16. ba = nx.barabasi_albert_graph(10, 5) 

  17. plt.subplot(223) 

  18. plt.title('barabasi_albert_graph') 

  19. nx.draw(ba, with_labels=True, font_weight='bold') 

  20. plt.axis('on') 

  21. plt.xticks([]) 

  22. plt.yticks([]) 


  23. red = nx.random_lobster(10, 0.9, 0.9) 

  24. plt.subplot(224) 

  25. plt.title('random_lobster') 

  26. nx.draw(red, with_labels=True, font_weight='bold') 

  27. plt.axis('on') 

  28. plt.xticks([]) 

  29. plt.yticks([]) 


  30. plt.show() 


随机graph生成器

2.6社交网络

  1. plt.subplots(2,2,figsize=(15,6)) 


  2. #返回Zachary的空手道俱乐部图。 

  3. G.clear() 

  4. G = nx.karate_club_graph() 

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

  6. nx.draw(G,with_labels=True) 

  7. plt.title('karate_club_graph') 

  8. plt.axis('on') 

  9. plt.xticks([]) 

  10. plt.yticks([]) 


  11. #戴维斯南方女性社交网络。 

  12. G.clear() 

  13. G = nx.davis_southern_women_graph() 

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

  15. nx.draw(G,with_labels=True) 

  16. plt.title('davis_southern_women_graph') 

  17. plt.axis('on') 

  18. plt.xticks([]) 

  19. plt.yticks([]) 


  20. plt.show() 


社交网络

2.7社区

  1. plt.subplots(2,2,figsize=(15,6)) 


  2. er = nx.caveman_graph(3,3) 

  3. plt.subplot(221) 

  4. plt.title('caveman_graph') 

  5. nx.draw(er, with_labels=True, font_weight='bold') 

  6. plt.axis('on') 

  7. plt.xticks([]) 

  8. plt.yticks([]) 


  9. ws = nx.random_partition_graph([10,10,10],.25,.01) 

  10. plt.subplot(222) 

  11. plt.title('random_partition_graph') 

  12. nx.draw(ws, with_labels=True, font_weight='bold') 

  13. plt.axis('on') 

  14. plt.xticks([]) 

  15. plt.yticks([]) 


  16. ba = nx.ring_of_cliques(8, 4) 

  17. plt.subplot(223) 

  18. plt.title('ring_of_cliques') 

  19. nx.draw(ba, with_labels=True, font_weight='bold') 

  20. plt.axis('on') 

  21. plt.xticks([]) 

  22. plt.yticks([]) 


  23. red = nx.windmill_graph(4,5) 

  24. plt.subplot(224) 

  25. plt.title('windmill_graph') 

  26. nx.draw(red, with_labels=True, font_weight='bold') 

  27. plt.axis('on') 

  28. plt.xticks([]) 

  29. plt.yticks([]) 


  30. plt.show() 


社区

2.8树

  1. #返回随机树 

  2. G.clear() 

  3. G = nx.random_tree(10) 

  4. nx.draw(G,with_labels=True) 

  5. plt.title('random_tree') 

  6. plt.axis('on') 

  7. plt.xticks([]) 

  8. plt.yticks([]) 


  9. plt.show() 


NetworkX系列教程(2)-graph生成器的更多相关文章

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

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

  2. NetworkX系列教程(1)-创建graph

    小书匠Graph图论 研究中经常涉及到图论的相关知识,而且常常面对某些术语时,根本不知道在说什么.前不久接触了NetworkX这个graph处理工具,发现这个工具已经解决绝大部分的图论问题(也许只是我 ...

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

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

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

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

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

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

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

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

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

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

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

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

  9. NetworkX系列教程(10)-算法之五:广度优先与深度优先

    小书匠Graph图论 重头戏部分来了,写到这里我感觉得仔细认真点了,可能在NetworkX中,实现某些算法就一句话的事,但是这个算法是做什么的,用在什么地方,原理是怎么样的,不清除,所以,我决定先把图 ...

随机推荐

  1. oracle笔记之计算年龄、工龄和TRUNC

    方法一:利用months_between 函数计算 SELECT TRUNC(months_between(sysdate, birthday)/12) AS agefrom dual; 方法二:日期 ...

  2. Shiro简介、入门案例、web容器的集成

    目的: shiro简介 Shiro入门案例 Shiro与web容器的集成 shiro简介(中文官网:https://www.w3cschool.cn/shiro/andc1if0.html) 1.什么 ...

  3. Linux下用命令来执行kettle文件资源库的文件ktr与kjb的方法

    转载地址: https://blog.csdn.net/zuolovefu/article/details/78083445 1. 准备工作 一个简单的job,一个简单的trans. trans:读取 ...

  4. vue npm run build 失败

    之前删除过 node-moudel 文件夹,然后 npm install 重新安装,一切OK.打包的时候,报错,找不到caniuse什么的.再删除node-moudel,重新cnpm install ...

  5. 在论坛中出现的比较难的sql问题:18(字符合并 整数解析星期几)

    原文:在论坛中出现的比较难的sql问题:18(字符合并 整数解析星期几) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...

  6. 在论坛中出现的比较难的sql问题:15(生成动态删除列语句 分组内多行转为多列)

    原文:在论坛中出现的比较难的sql问题:15(生成动态删除列语句 分组内多行转为多列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路. 1.如果去掉这个临时表中合计为0 ...

  7. .NET Core 使用swagger进行分组显示

    其实,和swagger版本管理类似;只是平时接口太多;不好供前端人员进行筛选. 下面进入主题: 首先: //注册Swagger生成器,定义一个和多个Swagger 文档 services.AddSwa ...

  8. 【转载】网站配置Https证书系列(三):IIS网站设置Http链接直接跳转Https安全连接

    Http链接请求是以明文的方式传输,在传输的过程中很容易被篡改数据,一个典型的例子就是运营商的网络劫持注入广告信息等,而Https请求则是安全加密的请求,报文数据以密文的形式进行传输.当IIS网站配置 ...

  9. 宽字节 多字节 mbstowcs wcstombs

    函数 size_t wcstombs(char *dest, const wchar_t *src, size_t n); //wide-character to a multibyte n:被写入到 ...

  10. Vue指令之`v-for`和`key`属性

    2.2.0+ 的版本里,**当在组件中使用** v-for 时,key 现在是必须的. 当 Vue.js 用 v-for 正在更新已渲染过的元素列表时,它默认用 “**就地复用**” 策略.如果数据项 ...