成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

實現動態展示多算法,這個Python庫助你發現網絡圖社區結構

新聞 前端 算法
熟知社區發現算法,你不能錯過這個 Python 庫。它涵蓋 Louvain 算法、Girvan-Newman 算法等多種社區發現算法,還具有可視化功能。

 [[382977]]

熟知社區發現算法,你不能錯過這個 Python 庫。它涵蓋 Louvain 算法、Girvan-Newman 算法等多種社區發現算法,還具有可視化功能。

網絡是由一些緊密相連的節點組成的,并且根據不同節點之間連接的緊密程度,網絡也可視為由不同簇組成。簇內的節點之間有著更為緊密的連接,不同簇之間的連接則相對稀疏。這種簇被稱為網絡中的社區結構(community structure)。

由此衍生出來的社區發現(community detection)算法用來發現網絡中的社區結構,這類算法包括 Louvain 算法、Girvan-Newman 算法以及 Bron-Kerbosch 算法等。

最近,機器之心在 GitHub 上發現了一個可以發現圖中社區結構的 Python 庫 communities,該庫由軟件工程師 Jonathan Shobrook 創建。

實現動態展示多算法,這個Python庫助你發現網絡圖社區結構

項目地址:https://github.com/shobrook/communities

首先,該庫可以實現以下幾種社區發現算法:

  • Louvain 算法
  • Girvan-Newman 算法
  • 層次聚類
  • 譜聚類
  • Bron-Kerbosch 算法

其次,用戶還可以使用 communities 庫來可視化上述幾種算法,下圖為空手道俱樂部(Zachary's karate club)網絡中 Louvain 算法的可視化結果:

實現動態展示多算法,這個Python庫助你發現網絡圖社區結構

該庫的安裝方法也非常簡單,可采用 pip 的方式安裝 communities,代碼如下:

  1. $ pip install communities 

對于這個 Python 庫,很多網友給予了高度評價,表示會去嘗試。

實現動態展示多算法,這個Python庫助你發現網絡圖社區結構

算法詳解

Louvain 算法

  1. louvain_method(adj_matrix : numpy.ndarray, n : int = None) -> list 

該算法來源于文章《Fast unfolding of communities in large networks》,簡稱為 Louvian。

作為一種基于模塊度(Modularity)的社區發現算法,Louvain 算法在效率和效果上都表現比較好,并且能夠發現層次性的社區結構,其優化的目標是最大化整個圖屬性結構(社區網絡)的模塊度。

Louvain 算法對最大化圖模塊性的社區進行貪婪搜索。如果一個圖具有高密度的群體內邊緣和低密度的群體間邊緣,則稱之為模圖。

示例代碼如下:

  1. from communities.algorithms import louvain_methodad 
  2.  
  3.  
  4. j_matrix = [...] 
  5. communities, _ = louvain_method(adj_matrix) 

Girvan-Newman 算法

  1. girvan_newman(adj_matrix : numpy.ndarray, n : int = None) -> list 

該算法來源于文章《Community structure in social and biological networks》。

Girvan-Newman 算法迭代刪除邊以創建更多連接的組件。每個組件都被視為一個 community,當模塊度不能再增加時,算法停止去除邊緣。

示例代碼如下:

  1. from communities.algorithms import girvan_newman 
  2.  
  3.  
  4. adj_matrix = [...] 
  5. communities, _ = girvan_newman(adj_matrix) 

層次聚類

  1. hierarchical_clustering(adj_matrix : numpy.ndarray, metric : str = "cosine", linkage : str = "single", n : int = None) -> list 

層次聚類實現了一種自底向上、分層的聚類算法。每個節點從自己 的社區開始,然后,隨著層次結構的建立,最相似的社區被合并。社區會一直被合并,直到在模塊度方面沒有進一步的進展。

示例代碼如下:

  1. from communities.algorithms import hierarchical_clustering 
  2.  
  3.  
  4. adj_matrix = [...] 
  5. communities = hierarchical_clustering(adj_matrix, metric="euclidean", linkage="complete"

譜聚類

  1. spectral_clustering(adj_matrix : numpy.ndarray, k : int) -> list 

這種類型的算法假定鄰接矩陣的特征值包含有關社區結構的信息。

示例代碼如下:

  1. from communities.algorithms import spectral_clustering 
  2.  
  3.  
  4. adj_matrix = [...] 
  5. communities = spectral_clustering(adj_matrix, k=5

Bron-Kerbosch 算法

  1. bron_kerbosch(adj_matrix : numpy.ndarray, pivot : bool = False) -> list 

Bron-Kerbosch 算法實現用于最大團檢測(maximal clique detection)。圖中的最大團是形成一個完整圖的節點子集,如果向該子集中添加其他節點,則它將不再完整。將最大團視為社區是合理的,因為團是圖中連接最緊密的節點群。因為一個節點可以是多個社區的成員,所以該算法有時會識別重疊的社區。

示例代碼如下:

  1. from communities.algorithms import bron_kerbosch 
  2.  
  3.  
  4. adj_matrix = [...] 
  5. communities = bron_kerbosch(adj_matrix, pivot=True) 

可視化

繪圖

  1. draw_communities(adj_matrix : numpy.ndarray, communities : list, dark : bool = False, filename : str = None, seed : int = 1

可視化圖(graph),將節點分組至它們所屬的社區和顏色編碼中。返回代表繪圖的 matplotlib.axes.Axes。示例代碼如下:

  1. from communities.algorithms import louvain_method 
  2. from communities.visualization import draw_communities 
  3.  
  4.  
  5. adj_matrix = [...] 
  6. communities, frames = louvain_method(adj_matrix) 
  7.  
  8.  
  9. draw_communities(adj_matrix, communities) 

可視化圖如下:

實現動態展示多算法,這個Python庫助你發現網絡圖社區結構

Louvain 算法的動圖展示

  1. louvain_animation(adj_matrix : numpy.ndarray, frames : list, dark : bool = False, duration : int = 15, filename : str = None, dpi : int = None, seed : int = 2

Louvain 算法在圖中的應用可以實現動圖展示,其中每個節點的顏色代表其所屬的社區,并且同一社區中的節點聚類結合在一起。

示例代碼如下:

  1. from communities.algorithms import louvain_method 
  2. from communities.visualization import louvain_animation 
  3.  
  4.  
  5. adj_matrix = [...] 
  6. communities, frames = louvain_method(adj_matrix) 
  7.  
  8.  
  9. louvain_animation(adj_matrix, frames) 

動圖展示如下:

實現動態展示多算法,這個Python庫助你發現網絡圖社區結構

 

 

責任編輯:張燕妮 來源: 機器之心Pro
相關推薦

2022-11-24 14:46:14

網絡社區發現

2011-03-02 09:09:10

2011-01-25 09:31:01

設計元素UIwebOS

2012-09-28 13:13:32

Win 7

2015-07-01 09:35:16

Java批量下載網絡圖片

2020-02-13 11:47:05

GitHub代碼開發者

2015-10-08 10:51:21

Build 10551多圖Windows 10

2011-01-07 13:33:07

Google平板系統蜂巢Android 3.0

2011-04-18 17:25:34

Symbian Ann諾基亞

2021-06-15 07:33:13

Java函數式編程

2021-02-25 15:21:27

Python 開發編程語言

2010-01-27 17:53:18

Android顯示網絡

2025-04-07 08:40:00

Python數據結構

2023-04-26 06:22:45

NLPPython知識圖譜

2011-01-13 10:51:12

百卓網絡上網行為管理網絡控制

2011-01-27 10:11:42

Android 3.0

2023-09-25 12:23:18

Python

2021-04-19 09:08:19

無向圖數據結構

2011-04-06 12:27:33

2021-08-31 09:45:15

神經網絡數據語音
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 不卡视频一区二区三区 | 午夜小电影 | 欧美日韩综合精品 | 国产精品污www一区二区三区 | 99国内精品久久久久久久 | 伦理午夜电影免费观看 | 成人在线播放网站 | 欧美视频二区 | 国产精品一区二区在线 | 99精品视频在线 | 亚洲欧美一区二区三区1000 | 99久久99 | 欧美日韩精品久久久免费观看 | 日韩高清国产一区在线 | 久色视频在线 | 国产精品免费一区二区三区四区 | 麻豆视频在线免费看 | 81精品国产乱码久久久久久 | 免费精品久久久久久中文字幕 | 午夜成人免费视频 | 91久色| 国产精品久久久久一区二区三区 | 一级黄色片美国 | 色就是色欧美 | 国产精品久久一区二区三区 | 国产激情91久久精品导航 | 成人av一区二区在线观看 | 一区二区在线 | 色免费在线视频 | 国产视频福利一区 | 天天干视频| 欧美精品一区二区三区四区 | 国产三级国产精品 | 麻豆av一区二区三区久久 | 欧美日韩亚洲一区 | 亚洲欧美精品在线观看 | 涩涩视频在线观看 | 久久精品一区二区三区四区 | 美国一级毛片a | 九九视频网 | 久久精品国产久精国产 |