由标签的子集igraph图

时间:2013-04-07 00:57:41

标签: r igraph

我试图通过边缘特征(如其标签)对igraph图进行子集化。在可重现的例子中,我通过一点修改从另一个帖子中无耻地偷走了,我希望能够将最好的朋友关系(BF)与家庭关系(FAM)分开:

edges <- matrix(c(103, 86, 24, 103, 103, 2, 92, 103, 87, 103, 103, 101, 103, 44), ncol=2, byrow=T)
g <- graph(as.vector(t(edges)))
E(g)[c(2:4,7)]$label<-"FAM"
E(g)[c(1,5,6)]$label<-"BF"

到目前为止我能做的最好的事情是显示有一种类型的领带的边缘:

E(g)[E(g)$label=="BF"]
V(g)[E(g)$label=="BF"]

2 个答案:

答案 0 :(得分:22)

怎么样:

gfam <- subgraph.edges(graph=g, eids=which(E(g)$label=="FAM"), delete.vertices = TRUE)
gbf <- subgraph.edges(graph=g, eids=which(E(g)$label=="BF"), delete.vertices = TRUE)

建议igraph /网络分析教程/无耻插件:http://sna.stanford.edu/rlabs.php

答案 1 :(得分:18)

我建议您阅读?V?E,了解如何选择边和顶点。一个非常紧凑和可读的问题解决方案是

subgraph.edges(g, E(g)[label=="FAM"])
subgraph.edges(g, E(g)[label=="BF"])

如果它们没有指定标签的事件边缘,也会删除顶点。有关详细信息,请参阅?subgraph.edges