igraph中有一个函数来计算no。每个连接组件的大小和基于属性的大小。 即。顶点子集由其属性“连接”。
library(igraph)
## create example graph
g1 <- graph.full(5)
V(g1)$name <- 1:5
g2 <- graph.full(5)
V(g2)$name <- 6:10
g3 <- graph.ring(5)
V(g3)$name <- 11:15
g <- g1 + g2 + g3 + edge('1', '6') + edge('1', '11')
##defining attribute to subset of vertices
hh<-1:vcount(g) %in% c(7,6,1,13,14)
g<-set.vertex.attribute(g, name="selected" ,value=0)
g<-set.vertex.attribute(g, name="selected",hh, value=1)
#plotted out
vc="[<-"(rep('black',vcount(g)),c(7,6,1,13,14),'red')
plot(g,vertex.color=vc, vertex.label.color="white")
此时我能想到的是仅使用选定的顶点进行重新编程并运行clusters
函数。有更简单的方法吗?
答案 0 :(得分:2)
您可以在igraph对象中使用induced.subgraph
或subgraph
依赖
clusters(induced.subgraph(g,V(g)[V(g)$selected == 1]))
$membership
[1] 1 1 1 2 2
$csize
[1] 3 2
$no
[1] 2