3

我正在尝试创建一个图形,然后用函数write.graph(包igraph)编写它。因此,我创建了距离矩阵

require(vegan)
data(dune)
dis <- vegdist(dune)

然后我明确定义行名:

x <- c("dune1")
for (i in 1: 20){
  n <- paste("dune", i, sep="")
  x <- append(x, n)

}
rownames(dune) <- x

通过以下过程,我通过最小生成树算法创建了一个无向图。

gg  <- graph.adjacency(as.matrix(dis), weighted=TRUE)
gg_mst <- as.undirected(mst(gg))

在这一点上,我想用 pajek 打开它。为了做到这一点,我使用 write.graph:

write.graph(gg_mst, "graph.net", format="pajek")

得到下图: 在此处输入图像描述

名字不见了!

不过,如果我使用不同的格式使用相同的功能:

write.graph(gg_mst, "graph.txt", format="ncol")

我获得了一个保存行名的文件:

dune1 dune3 0.448275862068966
dune2 dune3 0.341463414634146
dune2 dune10 0.294117647058824
dune3 dune4 0.270588235294118
...   ...   ...

它是与使用“ pajekwrite.graph格式相关的错误吗?

4

1 回答 1

3

您需要分配顶点的id属性,以便能够在 pajek 查看器中显示顶点的名称,例如这个http://vlado.fmf.uni-lj.si/pub%20/networks/pajek /default.htm或 gephi。需要修改几行代码,如下所示:

dis <- vegdist(dune)
x <- c()
for (i in 1: 20){
  n <- paste("dune", i, sep="")
  x <- append(x, n)  
}
gg  <- graph.adjacency(as.matrix(dis), weighted=TRUE)
gg_mst <- as.undirected(mst(gg))
V(gg_mst)$id <- x # assign the ids
write.graph(gg_mst, "graph.net", format="pajek")

使用 pajek 打开会正确显示顶点 ID。

在此处输入图像描述

于 2016-12-13T19:17:54.070 回答