網站首頁 編程語言 正文
使用工具
#導入模塊
import networkx as nx
import numpy as np
import matplotlib.pyplot as plt
import scipy.sparse as sp
準備數據
# 鄰接矩陣
Matrix = np.array(
[
[0, 1, 1, 1, 1, 1, 0, 0], # a
[0, 0, 1, 0, 1, 0, 0, 0], # b
[0, 0, 0, 1, 0, 0, 0, 0], # c
[0, 0, 0, 0, 1, 0, 0, 0], # d
[0, 0, 0, 0, 0, 1, 0, 0], # e
[0, 0, 1, 0, 0, 0, 1, 1], # f
[0, 0, 0, 0, 0, 1, 0, 1], # g
[0, 0, 0, 0, 0, 1, 1, 0] # h
]
)
轉化臨界矩陣
def get_matrix_triad(coo_matrix , data=False):
'''
獲取矩陣的元組表示 (row,col)
data 為 True 時 (row,col,data)
:dependent scipy
:param coo_matrix: 三元組表示的稀疏矩陣 類型可以為 numpy.ndarray
:param data: 是否需要 data值
:return:
list
'''
# 檢查類型
if not sp.isspmatrix_coo(coo_matrix):
# 轉化為三元組表示的稀疏矩陣
coo_matrix = sp.coo_matrix(coo_matrix)
# nx3的矩陣 列分別為 矩陣行,矩陣列及對應的矩陣值
temp = np.vstack((coo_matrix.row , coo_matrix.col , coo_matrix.data)).transpose()
return temp.tolist()
測試
edags = get_matrix_triad(Matrix)
-->
[[0.0, 0.0, 1.0],
[0.0, 1.0, 1.0],
[0.0, 2.0, 1.0],
[0.0, 3.0, 1.0],
[0.0, 4.0, 1.0],
[0.0, 5.0, 1.0],
[1.0, 1.0, 1.0],
[1.0, 2.0, 1.0],
[1.0, 4.0, 1.0],
[2.0, 2.0, 1.0],
[2.0, 3.0, 1.0],
[3.0, 3.0, 1.0],
[3.0, 4.0, 1.0],
[4.0, 4.0, 1.0],
[4.0, 5.0, 1.0],
[5.0, 2.0, 1.0],
[5.0, 5.0, 1.0],
[5.0, 6.0, 1.0],
[5.0, 7.0, 1.0],
[6.0, 5.0, 1.0],
[6.0, 6.0, 1.0],
[6.0, 7.0, 1.0],
[7.0, 5.0, 1.0],
[7.0, 6.0, 1.0],
[7.0, 7.0, 1.0]]
創建圖
# 創建一個沒有邊,沒有節點的空圖Graph
G = nx.Graph()
添加節點
按照節點的個數添加節點
H = nx.path_graph(Matrix.shape[0])
G.add_nodes_from(H)
添加邊
G.add_edges_from(edags) #添加邊
# 若數據含有權重,及 get_matrix_triad() 中 data = True ,則使用
G.add_weighted_edges_from(edags)
繪圖
colors = np.arange(Matrix.shape[0])
nx.draw(G,pos=nx.spring_layout(G),node_color=colors)
plt.show()
擴展
美化圖
合理使用**draw_networkx ()**中的參數,來美化圖
draw_networkx()
https://networkx.github.io/documentation/stable/reference/generated/networkx.drawing.nx_pylab.draw_networkx.html#networkx.drawing.nx_pylab.draw_networkx
總結
原文鏈接:https://blog.csdn.net/yf289178199/article/details/90238328
相關推薦
- 2022-11-14 flutter中使用流式布局示例詳解_Android
- 2022-12-15 conda創建環境過程出現"Solving?environment:?failed"報錯的詳細解決方
- 2022-04-15 C語言的位段與枚舉詳解_C 語言
- 2022-04-01 maven的settings.xml文件中配置多個nexus倉庫
- 2022-08-01 C#串口編程System.IO.Ports.SerialPort類_C#教程
- 2023-01-28 詳解如何利用C#實現漢字轉拼音功能_C#教程
- 2022-06-11 .Net項目在Docker容器中開發部署_實用技巧
- 2022-01-30 判斷element Ui 表格(el-table)中復選框中的選中狀態
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支