r - 如何在 R 的 igraph 中排列网络?

标签 r network-programming igraph montecarlo

我正在尝试在 R 中编写蒙特卡洛过程的代码。我的目标是估计为 igraph 包格式化的加权、单部分、无向网络计算的度量的重要性。

到目前为止,我在代码中包含了以下步骤:

1。创建加权、单分、无向网络并计算观察到的 Louvain 模块化

nodes <- read.delim("nodes.txt")
links <- read.delim("links.txt")
anurosnet <- graph_from_data_frame(d=links, vertices=nodes, directed=F) 
anurosnet

modularity1 = cluster_louvain(anurosnet)
modularity1$modularity #observed value 

obs=modularity1$modularity
obs
real<-data.frame(obs)
real

2。创建空向量

Nperm = 9 #I am starting with a low n, but intend to use at least 1000 permutations
randomized.modularity=matrix(nrow=length(obs),ncol=Nperm+1)
row.names(randomized.modularity)=names(obs)
randomized.modularity[,1]=obs 
randomized.modularity

3。对原始网络进行置换,保留其特征,计算所有随机网络的 Louvain 模块性,并将结果编译到向量中

i<-1
while(i<=Nperm){ 

  randomnet <- rewire(anurosnet, with=each_edge(0.5)) #rewire vertices with constant probability
  E(randomnet)$weight <- sample(E(anurosnet)$weight) #shuffle initial weights and assign them randomly to edges

  mod<-(cluster_louvain(randomnet))

  mod$modularity

  linha = mod$modularity

  randomized.modularity[,i+1]=linha
  print(i)
  i=i+1
}
randomized.modularity #Here the result is not as expected

4。根据随机值的分布绘制观测值

niveis<-row.names(randomized.modularity)
for(k in niveis)
{
  if(any(is.na(randomized.modularity[k,]) == TRUE))
  {
    print(c(k, "metrica tem NA"))
  } else {
    nome.arq<- paste("modularity",k,".png", sep="")
    png(filename= nome.arq, res= 300, height= 15, width=21, unit="cm")
    plot(density(randomized.modularity[k,]), main="Observed vs. randomized",)
    abline(v=obs[k], col="red", lwd=2, xlab="")
    dev.off()
    print(k)
    nome.arq<- paste("Patefield_Null_mean_sd_",k,".txt", sep="")
    write.table(cbind(mean(randomized.modularity[k,]),sd(randomized.modularity[k,])), file=paste(nome.arq,sep=""), 
                sep=" ",row.names=TRUE,col.names=FALSE)
  }
}

5。估计 P 值(显着性)

significance=matrix(nrow=nrow(randomized.modularity),ncol=3)
row.names(significance)=row.names(randomized.modularity)
colnames(significance)=c("p (rand <= obs)", "p (rand >= obs)", "p (rand=obs)")

signif.sup=function(x) sum(x>=x[1])/length(x)
signif.inf=function(x) sum(x<=x[1])/length(x)
signif.two=function(x) ifelse(min(x)*2>1,1,min(x)*2)

significance[,1]=apply(randomized.modularity,1,signif.inf)
significance[,2]=apply(randomized.modularity,1,signif.sup)
significance[,3]=apply(significance[,-3],1,signif.two)

significance

第 3 步出了问题。我预计向量会填充 10 个值,但由于某种原因它在一段时间后停止了。

槽“mod$modularity”突然收到 2 个值而不是 1。

代码开头提到的两个TXT文件可以从这里下载:

https://1drv.ms/t/s!AmcVKrxj94WClv8yQyqyl4IWk5mNvQ https://1drv.ms/t/s!AmcVKrxj94WClv8z_Pow5Tg2U7mjLw

你能帮我一下吗?

最佳答案

您的错误是由于维度与您的randomized.modularity矩阵以及一些随机模块化结果不匹配造成的。在您的示例中,您的矩阵最终为 [1 x Nperm] 但有时在排列过程中会返回 2 个模块化分数。为了解决这个问题,我只需将结果存储在列表中。由于模块性分数不匹配,因此需要调整其余的分析。

library(igraph)

nodes <- read.delim("nodes.txt")
links <- read.delim("links.txt")
anurosnet <- graph_from_data_frame(d=links, vertices=nodes, directed=F) 
anurosnet

modularity1 = cluster_louvain(anurosnet)
modularity1$modularity #observed value 

obs <- modularity1$modularity
obs
real<-data.frame(obs)
real

Nperm = 100 #I am starting with a low n, but intend to use at least 1000 permutations
#randomized.modularity <- matrix(nrow=length(obs),ncol=Nperm+1)
#row.names(randomized.modularity) <- names(obs)
randomized.modularity <- list()
randomized.modularity[1] <- obs 
randomized.modularity


for(i in 1:Nperm){ 

  randomnet <- rewire(anurosnet, with=each_edge(0.5)) #rewire vertices with constant probability
  E(randomnet)$weight <- sample(E(anurosnet)$weight) #shuffle initial weights and assign them randomly to edges

  mod <- (cluster_louvain(randomnet))      
  mod$modularity      
  linha = mod$modularity     
  randomized.modularity <- c(randomized.modularity, list(linha))

}

randomized.modularity

编写循环的更好方法

randomized.modularity <- lapply(seq_len(Nperm), function(x){  
                                            randomnet <- rewire(anurosnet, with=each_edge(0.5)) #rewire vertices with constant probability
                                            E(randomnet)$weight <- sample(E(anurosnet)$weight) #shuffle initial weights and assign them randomly to edges
                                            return(cluster_louvain(randomnet)$modularity)
                                          })

关于r - 如何在 R 的 igraph 中排列网络?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55523684/

相关文章:

json - 在 R 中使用 fromJSON 时处理 NaN

c - 从字节数组中解压整数

r - igraph中最低的共同祖先

linux - ethercat 模块的以太网驱动程序

c# - 为什么我的简单 lidgren 客户端使用这么多内存?

r - igraph + R 顶点按条件着色(最好是连续颜色)

大图中的随机 session : efficient way of adding or deleting edges of a graph in R

r - 如何识别两(或更多)行不同(相同 ID)的列?

r - 将矩阵转换为 r 中的数据帧

r - ggplot2中的=“h”类型的代码