複数のアルゴリズムの動的な表示を実装するこのPythonライブラリは、ネットワークグラフのコミュニティ構造を発見するのに役立ちます。

複数のアルゴリズムの動的な表示を実装するこのPythonライブラリは、ネットワークグラフのコミュニティ構造を発見するのに役立ちます。

[[382977]]

コミュニティ発見アルゴリズムに精通しているなら、この Python ライブラリを見逃すことはできません。 LouvainアルゴリズムやGirvan-Newmanアルゴリズムなどのさまざまなコミュニティ発見アルゴリズムをカバーし、可視化機能も備えています。

ネットワークは、密接に接続された多数のノードで構成されており、異なるノード間の接続の程度に応じて、ネットワークは異なるクラスターで構成されていると考えることもできます。クラスター内のノードはより密接に接続されていますが、異なるクラスター間の接続は比較的疎です。このようなクラスターは、ネットワーク内のコミュニティ構造と呼ばれます。

これから派生したコミュニティ検出アルゴリズムは、ネットワーク内のコミュニティ構造を検出するために使用されます。このようなアルゴリズムには、Louvain アルゴリズム、Girvan-Newman アルゴリズム、Bron-Kerbosch アルゴリズムなどがあります。

最近、Machine Heart は、グラフ内のコミュニティ構造を検出できる、communities という Python ライブラリを GitHub で発見しました。このライブラリは、ソフトウェア エンジニアの Jonathan Shobrook によって作成されました。

プロジェクトアドレス: https://github.com/shobrook/communities

まず、ライブラリは次のコミュニティ検出アルゴリズムを実装できます。

  • ルーヴァンアルゴリズム
  • ガーバン・ニューマンアルゴリズム
  • 階層的クラスタリング
  • スペクトルクラスタリング
  • ブロン・ケルボッシュアルゴリズム

次に、ユーザーはコミュニティ ライブラリを使用して、上記のアルゴリズムを視覚化することもできます。次の図は、Zachary の空手クラブ ネットワークにおける Louvain アルゴリズムの視覚化結果を示しています。

このライブラリのインストール方法も非常に簡単です。コミュニティをインストールするには、pip を使用します。コードは次のとおりです。

  1. $ pip インストールコミュニティ

多くのネットユーザーがこの Python ライブラリを高く評価し、試してみると述べました。

アルゴリズムの詳細な説明

ルーヴァンアルゴリズム

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

このアルゴリズムは、「大規模ネットワークにおけるコミュニティの高速展開」という記事 (略称 Louvian) から引用したものです。

モジュール性に基づくコミュニティ発見アルゴリズムとして、Louvain アルゴリズムは効率性と有効性の面で比較的優れたパフォーマンスを発揮し、階層的なコミュニティ構造を発見することができます。その最適化目標は、グラフ属性構造 (コミュニティ ネットワーク) 全体のモジュール性を最大化することです。

Louvain アルゴリズムは、グラフのモジュール性を最大化するコミュニティを貪欲に検索します。グラフのグループ内エッジの密度が高く、グループ間エッジの密度が低い場合、そのグラフはモジュール グラフと呼ばれます。

サンプルコードは次のとおりです。

  1. community.algorithms から louvain_methodadをインポートします
  2. j_matrix = [...]
  3. コミュニティ、_ = louvain_method(adj_matrix)

ガーバン・ニューマンアルゴリズム

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

このアルゴリズムは、「社会的および生物学的ネットワークにおけるコミュニティ構造」という記事から引用したものです。

Girvan-Newman アルゴリズムは、エッジを繰り返し削除して、より接続されたコンポーネントを作成します。各コンポーネントはコミュニティとして扱われ、モジュール性をこれ以上増加できなくなった時点でアルゴリズムはエッジの削除を停止します。

サンプルコードは次のとおりです。

  1. community.algorithms から girvan_newmanをインポートします
  2. adj_matrix = [...]
  3. コミュニティ、_ = girvan_newman(adj_matrix)

階層的クラスタリング

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

階層的クラスタリングは、ボトムアップの階層的クラスタリング アルゴリズムを実装します。各ノードは独自のコミュニティから始まり、階層が構築されるにつれて、最も類似したコミュニティが統合されます。モジュール化がこれ以上進展しなくなるまで、コミュニティは統合されます。

サンプルコードは次のとおりです。

  1. community.algorithms から hierarchical_clusteringをインポートします
  2. adj_matrix = [...]
  3. コミュニティ = hierarchical_clustering(adj_matrix、メトリック = "ユークリッド" 、リンク = "完全" )

スペクトルクラスタリング

  1. spectral_clustering (adj_matrix: numpy.ndarray, k: int ) -> リスト

このタイプのアルゴリズムでは、隣接行列の固有値にコミュニティ構造に関する情報が含まれていると想定しています。

サンプルコードは次のとおりです。

  1. community.algorithms から spectral_clusteringをインポートします
  2. adj_matrix = [...]
  3. コミュニティ = スペクトルクラスタリング(adj_matrix, k= 5 )

ブロン・ケルボッシュアルゴリズム

  1. bron_kerbosch(adj_matrix: numpy.ndarray、pivot: bool = False) -> リスト

最大クリーク検出のための Bron-Kerbosch アルゴリズムの実装。グラフ内の最大クリークは、完全なグラフを形成するノードのサブセットであり、このサブセットにノードを追加すると、完全ではなくなります。クリークはグラフ内で最も密接に接続されたノードのグループであるため、最大のクリークをコミュニティと見なすのが妥当です。ノードは複数のコミュニティのメンバーになることができるため、アルゴリズムは重複するコミュニティを識別することがあります。

サンプルコードは次のとおりです。

  1. community.algorithms から bron_kerboschをインポート
  2. adj_matrix = [...]
  3. コミュニティ = bron_kerbosch(adj_matrix, pivot=True)

視覚化

描画

  1. draw_communities(adj_matrix: numpy.ndarray、コミュニティ: リスト、dark: bool = False、ファイル名: str = None、シード: int = 1 )

グラフを視覚化し、ノードを所属するコミュニティごとにグループ化し、色分けします。プロットを表す matplotlib.axes.Axes を返します。サンプルコードは次のとおりです。

  1. community.algorithms から louvain_methodをインポートします
  2. community.visualization から draw_communitiesをインポートします
  3. adj_matrix = [...]
  4. コミュニティ、フレーム = louvain_method(adj_matrix)
  5. draw_communities(adj_matrix、コミュニティ)

視覚化は次のようになります。

ルーヴァンアルゴリズムのアニメーションイラスト

  1. louvain_animation(adj_matrix: numpy.ndarray、フレーム: リスト、dark: bool = False、duration: int = 15 、filename: str = None、dpi: int = None、seed: int = 2 )

グラフに Louvain アルゴリズムを適用すると、アニメーション化されたグラフィック表示を実装できます。各ノードの色は、そのノードが属するコミュニティを表し、同じコミュニティ内のノードはクラスター化されます。

サンプルコードは次のとおりです。

  1. community.algorithms から louvain_methodをインポートします
  2. community.visualization から louvain_animationをインポート
  3. adj_matrix = [...]
  4. コミュニティ、フレーム = louvain_method(adj_matrix)
  5. louvain_animation(adj_matrix、フレーム)

アニメーション画像を以下に示します。

<<:  世界を驚かせたNASAの火星無人機はどのように設計されたのか?

>>:  AI面接官はこんなに簡単に騙される!本棚の写真を動画の背景として使用すると好感度が 15% 上昇します

ブログ    
ブログ    

推薦する

新たな美容問題:彼女がAIではないことをどうやって証明するか

私の家族の皆さん、人間として生きることが昨今こんなにも困難になっているとは誰が想像したでしょうか?最...

AIもボトルネックに遭遇。人工知能技術のストレージ性能要件の分析

2020年は多くの人々にとって忘れられない年です。新型コロナウイルス感染症の突然の発生は、ほぼすべて...

ドローンは人気があり、3つの主要なアプリケーションが農家の役に立つ

今日は二十四節気の一つ、白露節気です。白露節気の季節には、我が国のほとんどの地域が秋の収穫期に入り、...

わずか6秒で、AIはあなたの声を聞くだけであなたの外見を説明できる

信じられますか?人工知能は最近、あなたの声からわずか6秒で性別、年齢、人種を判別し、さらにはあなたの...

...

Google が地図「タイムマシン」を公開: 100 年前のあなたの街はどんな様子だったでしょうか?

この記事はAI新メディアQuantum Bit(公開アカウントID:QbitAI)より許可を得て転載...

交換されますか? GPT4コードインタープリター完全自動

こんにちは、みんな。今日は、GPT-4 コード インタープリターがデータ分析、科学研究の描画、機械学...

心でタイピング、中国で脳コンピューターインターフェースの新記録が樹立されました!

手やキーボードを使わず、思考だけに頼って、1分間に691.55ビットをコンピューター画面に出力できま...

...

文書翻訳における人工知能: 効率化の新時代

今日、言語を超えた効果的なコミュニケーションはこれまで以上に重要になっています。企業が新しい市場に進...

GenAIは主流になるが、CIOの行動は遅い

過去2週間、OpenAIの創設者サム・アルトマン氏は取締役会により解雇され、関連メンバーはマイクロソ...

中国の女性医師が効率的なNASアルゴリズムを提案:AutoMLは一度トレーニングするだけで数十億のハードウェアに適応できる

現在、カリフォルニア大学リバーサイド校が率いるチームは、ジョージ・メイソン大学およびノー​​トルダム...

これらの比較的成功している人工知能アプリケーションを使用したことがありますか?

人工知能に関して言えば、人気の科学映画をいくつか挙げなければなりません。多くの映画では、人工知能ロボ...

屈原·漁師のアルゴリズムの追求

屈原・漁夫のアルゴリズムの追求を分析する前に、「漁夫」の原文を見てみましょう。屈原は流刑になった後、...

...