绘制igraph网络像Gephi Force Atlas 2

时间:2015-01-19 10:01:35

标签: r plot igraph gephi

我有一个具有以下特征的网络(igraph):

>g
IGRAPH DN-- 3370 16699 --
+ attr: name (v/c), grupo (v/n), year (v/n), grupo.freq (v/n),
  grupo.perc (v/n), vertex.frame.size (v/n), color (v/c),
  vertex.frame.color (v/c), grupo (e/n), year (e/n), color (e/c)
make ping之后

具有以下组:

>table(V(g)$grupo)
   1    2    8
1516 1367  487

我对可以突出显示组(V(g)$grupo)之间关系的视图感兴趣。我将软件Gephi与布局Force Atlas 2一起用于下一张图片: http://i.imgur.com/VbcsHtl.png

我的问题是,如何在R?

中得到类似的结果

我正在使用以下代码:

colbar <- rainbow(length(table(V(g)$grupo)))
V(g)$color <- colbar
E(g)$color <- colbar
V(g)$vertex.frame.color <- colbar
V(g)$vertex.frame.size <- 0.1

plot.igraph(
            g,
            layout=layout.fruchterman.reingold.grid,
            vertex.label=NA,
            vertex.size=1,
            edge.lty=1,
            edge.arrow.size=0.0000001
            )

点击链接下载我在csvRdata中使用的数据: http://www.datafilehost.com/d/855e3e86

3 个答案:

答案 0 :(得分:3)

现在可以使用R中用于生成Force Atlas 2布局的代码:https://github.com/adolfoalvarez/Force-Atlas-2

布局尚未作为包开发,因此您需要将代码源代码转换为R,并使用&#34; igraph&#34;包。

用法是:

library(igraph)
g <- graph.ring(100)
layout.forceatlas2(g, iterations=10000, plotstep=500)

答案 1 :(得分:3)

首先,获取ForceAtlas2包。

install.packages("devtools")
if (!require("ForceAtlas2")) devtools::install_github("analyxcompany/ForceAtlas2")
library("ForceAtlas2")

然后,要使用布局g渲染图l,请执行以下操作(此处包含所有可用的布局参数):

g <- erdos.renyi.game(1000, 1/1000)
l <- layout.forceatlas2(g, directed=TRUE, iterations = 100, 
                           linlog = FALSE, pos = NULL, nohubs = FALSE, 
                           k = 400, gravity=1, ks=0.1, ksmax=10, delta = 1,  
                           center=NULL, tolerance = 0.1, dim = 2,
                           plotstep=10, plotlabels=TRUE)
plot(g,layout=l)

如果您愿意,可以在绘图功能中提供vertex.size = 3, vertex.color = "red"等选项。

答案 2 :(得分:1)

现在@ciberalcito提到的ForceAtlas2函数是在R包中实现的。请检查https://github.com/analyxcompany/ForceAtlas2