3

首先,我想说我已经阅读了这个问题的答案:“R“igraph”包邻居函数的问题”,我试图解决我的问题,但我做不到。我试图将我的问题作为后续评论提出,但由于声誉低下,我无法提出,因此我提出了这个新问题。现在这是我的问题:我对邻居函数有同样的问题,正如它在 “igraph”包邻居函数中所解释的那样,但是当我尝试Gabor Csardi给出的解决方案时,我刚刚收到 null 作为结果。我附上了那部分我的代码也在这里。我会非常感谢任何帮助和回答。我的桌子:

edgelist <- read.table(text = "
1 2
2 3
3 4
4 5
3 6
6 7")
library(igraph)
graph <- graph.data.frame(edgelist)

str(graph)
## IGRAPH DN-- 7 6 -- 
## + attr: name (v/c)
## + edges (vertex names):
## [1] 1->2 2->3 3->4 4->5 3->6 6->7

现在,如果我想要节点 3 的邻居,它应该是

2, 4, 6

但我得到的结果是:

2, 4, 5

我注意到它改变了我的节点的顺序。正如我在尝试在堆栈溢出中找到的解决方案之前解释的那样,但结果为 null:

graph$name[neighbors(graph, 3)]
   NULL

我不知道我还能做什么,我会很感激任何帮助。

4

2 回答 2

7

在我们开始之前,您应该小心不要混淆给定顶点的标签/名称和索引/编号。当您将这两个数字用于标签和索引时,事情很快就会变得混乱。为避免所有混淆,我在这里使用了字母

edgelist <- read.table(text = "
A B
B C
C D
D E
C F
F G")  

library(igraph)
graph <- graph.data.frame(edgelist)
str(graph)
#IGRAPH DN-- 7 6 -- 
# + attr: name (v/c)
# + edges (vertex names):
# [1] A->B B->C C->D D->E C->F F->G

要查看正在处理的内容,我们绘制它:

plot(graph)

伊姆古尔

要获取邻居的索引,请执行以下操作:(记住有一个mode参数)

neighbors(graph, 3, mode = "total")  # Index of neighbours by index
## [1] 2 4 5
neighbors(graph, "C", mode = "total")  # Index of neighbours by label
## [1] 2 4 5

要执行 Gabor 建议的操作,您需要执行以下操作。(我认为他在帖子中的意思是错过V( )并写了)graph$nameV(graph)$name

# Label of neighbours by label
V(graph)$name[neighbors(graph, "C", mode = "total")]
## [1] "B" "D" "F"

这给出了相应“邻居”的标签。这确实与图像一致。

编辑哎呀。我搞砸了。用来E()代替V(). 它似乎按预期工作。对不起。

于 2015-03-17T11:01:10.130 回答
0

或者,您可以使用 which 为您提供所需的索引:

neighbors(g,which(V(g)$name %in% 'A'),mode='in')
于 2015-08-28T15:32:33.697 回答