An R package for the implementation of the "Smith-Pittman" (2024) community detection algorithm. Compatible with the igraph ecosystem.
data:image/s3,"s3://crabby-images/b72b4/b72b41d94df50a0bb81399af5c40d2ab0a6e27a4" alt=""
data:image/s3,"s3://crabby-images/72c6b/72c6b99bbf9ad8f294ec23bf7f4c08533b871aad" alt=""
To install the stable release of this package from CRAN run:
install.packages("ig.degree.betweenness")
To install the development version of this package run:
# install.packages("devtools")
devtools::install_github("benyamindsmith/ig.degree.betweenness")
Applying the Smith-Pittman algorithm can be done by making use of the cluster_degree_betweenness()
.
An example of using the code is:
library(igraphdata)
library(ig.degree.betweenness)
data("karate")
sp <- cluster_degree_betweenness(karate)
plot(
sp,
karate,
main= "Smith-Pittman Clustering"
)
data:image/s3,"s3://crabby-images/78000/78000bda8dfbbd711f070a91952f5723e59ce7cb" alt=""
The present limitations of using this algorithm is that graphs are required to be labeled for the operations to work. For unlabeled graphs, graphs can be prepared with the prep_unlabled_graph()
function.
Example:
library(igraph)
library(igraphdata)
library(ig.degree.betweenness)
data("UKfaculty")
# Making graph undirected so it looks nicer when its plotted
uk_faculty <- prep_unlabeled_graph(UKfaculty) |>
as.undirected()
ndb <- cluster_degree_betweenness(uk_faculty)
plot(
ndb,
uk_faculty,
main= "Smith-Pittman Clustering for UK Faculty"
)
data:image/s3,"s3://crabby-images/f5787/f57874010d6910c97e0eb51b998ffc259703a1ac" alt=""