Finds the optimal community structure by maximizing modularity exactly. Very slow - only use for small networks (<50 nodes).
Arguments
- x
Network input
- weights
Edge weights. NULL uses network weights, NA for unweighted.
- ...
Additional arguments passed to
to_igraph
References
Brandes, U., Delling, D., Gaertler, M., Gorke, R., Hoefer, M., Nikoloski, Z., & Wagner, D. (2008). On modularity clustering. IEEE Transactions on Knowledge and Data Engineering, 20(2), 172-188.
Examples
g <- igraph::make_ring(10)
comm <- community_optimal(g)
membership(comm)
#> 1 2 3 4 5 6 7 8 9 10
#> 1 1 2 2 2 3 3 3 3 1
net <- as_cograph(matrix(runif(25), 5, 5))
com_op(net)
#> Community structure (optimal)
#> Nodes: 5 | Communities: 2 | Modularity: 0.2553
#> Sizes: 3, 2
#>
#> node community
#> 1 1
#> 2 1
#> 3 2
#> 4 2
#> 5 1
