Skip to content

Commit

Permalink
🆕 wCommunity algorithm
Browse files Browse the repository at this point in the history
  • Loading branch information
GiulioRossetti committed Sep 15, 2020
1 parent b8a6c0d commit 9116f59
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 50 deletions.
42 changes: 1 addition & 41 deletions cdlib/algorithms/crisp_partition.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,6 @@
from cdlib.algorithms.internal.AGDL import Agdl
from cdlib.algorithms.internal.FuzzyCom import fuzzy_comm
from cdlib.algorithms.internal.Markov import markov
from cdlib.algorithms.internal.weightedCommunity import weightedCommunity
from karateclub import EdMot
import markov_clustering as mc
from chinese_whispers import chinese_whispers as cw
Expand All @@ -48,7 +47,7 @@
__all__ = ["louvain", "leiden", "rb_pots", "rber_pots", "cpm", "significance_communities", "surprise_communities",
"greedy_modularity", "der", "label_propagation", "async_fluid", "infomap", "walktrap", "girvan_newman", "em",
"scan", "gdmp2", "spinglass", "eigenvector", "agdl", "frc_fgsn", "sbm_dl", "sbm_dl_nested",
"markov_clustering", "edmot", "chinesewhispers", "wCommunity"]
"markov_clustering", "edmot", "chinesewhispers"]


def girvan_newman(g_original, level):
Expand Down Expand Up @@ -1131,42 +1130,3 @@ def edmot(g_original, component_count=2, cutoff=10):
coms = [list(c) for c in coms_to_node.values()]

return NodeClustering(coms, g_original, "EdMot", method_parameters={"component_count": component_count, "cutoff": cutoff})


def wCommunity(g_original, min_bel_degree=0.7, threshold_bel_degree=0.7, weightName="weight"):
"""
Algorithm to identify overlapping communities in weighted graphs
:param g_original: a networkx/igraph object
:param min_bel_degree: the tolerance, in terms of beloging degree, required in order to add a node in a community
:param threshold_bel_degree: the tolerance, in terms of beloging degree, required in order to add a node in a 'NLU' community
:param weightName: name of the edge attribute containing the weights
:return: NodeClustering object
:Example:
>>> from cdlib import algorithms
>>> import networkx as nx
>>> G = nx.karate_club_graph()
>>> nx.set_edge_attributes(G, values=1, name='weight')
>>> coms = algorithms.wCommunity(G, min_bel_degree=0.6, threshold_bel_degree=0.6)
:References:
Chen, D., Shang, M., Lv, Z., & Fu, Y. (2010). Detecting overlapping communities of weighted networks via a local algorithm. Physica A: Statistical Mechanics and its Applications, 389(19), 4177-4187.
.. note:: Implementation provided by Marco Cardia <cardiamc@gmail.com> and Francesco Sabiu <fsabiu@gmail.com> (Computer Science Dept., University of Pisa, Italy)
"""
g = convert_graph_formats(g_original, ig.Graph)
# Initialization
comm = weightedCommunity(g, min_bel_degree=min_bel_degree, threshold_bel_degree=threshold_bel_degree,
weightName=weightName)
# Community computation
comm.computeCommunities()
# Result
coms = comm.getCommunities()
coms = [list(c) for c in coms]
return NodeClustering(coms, g_original, "wCommunity",
method_parameters={"min_bel_degree": min_bel_degree,
"threshold_bel_degree": threshold_bel_degree, 'weightName': weightName},
overlap=True)
8 changes: 0 additions & 8 deletions cdlib/algorithms/internal/weightedCommunity.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,3 @@
import pandas as pd
import numpy as np
from igraph import *
import matplotlib.pyplot as plt
import time
import itertools
from random import sample

__authors__ = ['Marco Cardia <cardiamc@gmail.com>', 'Francesco Sabiu <fsabiu@gmail.com>']


Expand Down
45 changes: 44 additions & 1 deletion cdlib/algorithms/overlapping_partition.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,12 @@
from cdlib.algorithms.internal.multicom import MultiCom
from cdlib.algorithms.internal.PercoMCV import percoMVC
from karateclub import DANMF, EgoNetSplitter, NNSED, MNMF, BigClam
from cdlib.algorithms.internal.weightedCommunity import weightedCommunity
from ASLPAw_package import ASLPAw

__all__ = ["ego_networks", "demon", "angel", "node_perception", "overlapping_seed_set_expansion", "kclique", "lfm",
"lais2", "congo", "conga", "lemon", "slpa", "multicom", "big_clam", "danmf", "egonet_splitter", "nnsed",
"nmnf", "aslpaw", "percomvc"]
"nmnf", "aslpaw", "percomvc", "wCommunity"]


def ego_networks(g_original, level=1):
Expand Down Expand Up @@ -833,3 +834,45 @@ def percomvc(g_original):
communities = percoMVC(g)

return NodeClustering(communities, g_original, "PercoMVC", method_parameters={}, overlap=True)

def wCommunity(g_original, min_bel_degree=0.7, threshold_bel_degree=0.7, weightName="weight"):
"""
Algorithm to identify overlapping communities in weighted graphs
:param g_original: a networkx/igraph object
:param min_bel_degree: the tolerance, in terms of beloging degree, required in order to add a node in a community
:param threshold_bel_degree: the tolerance, in terms of beloging degree, required in order to add a node in a 'NLU' community
:param weightName: name of the edge attribute containing the weights
:return: NodeClustering object
:Example:
>>> from cdlib import algorithms
>>> import networkx as nx
>>> G = nx.karate_club_graph()
>>> nx.set_edge_attributes(G, values=1, name='weight')
>>> coms = algorithms.wCommunity(G, min_bel_degree=0.6, threshold_bel_degree=0.6)
:References:
Chen, D., Shang, M., Lv, Z., & Fu, Y. (2010). Detecting overlapping communities of weighted networks via a local algorithm. Physica A: Statistical Mechanics and its Applications, 389(19), 4177-4187.
.. note:: Implementation provided by Marco Cardia <cardiamc@gmail.com> and Francesco Sabiu <fsabiu@gmail.com> (Computer Science Dept., University of Pisa, Italy)
"""

if ig is None:
raise ModuleNotFoundError("Optional dependency not satisfied: install igraph to use the selected feature.")

g = convert_graph_formats(g_original, ig.Graph)
# Initialization
comm = weightedCommunity(g, min_bel_degree=min_bel_degree, threshold_bel_degree=threshold_bel_degree,
weightName=weightName)
# Community computation
comm.computeCommunities()
# Result
coms = comm.getCommunities()
coms = [list(c) for c in coms]
return NodeClustering(coms, g_original, "wCommunity",
method_parameters={"min_bel_degree": min_bel_degree,
"threshold_bel_degree": threshold_bel_degree, 'weightName': weightName},
overlap=True)

0 comments on commit 9116f59

Please sign in to comment.