r - 关于 igraph::count_multiple() 的说明

标签 r igraph

我希望 igraph::count_multiple()计算边的多重性,文档似乎反射(reflect)了这一点。但是,它并不总是产生整数。

一个例子:

library(igraph)
library(dplyr)

data("USairports", package = "igraphdata")

期望:计算边数,同时对相关顶点进行分组......

(
manualish_count <- USairports %>% 
  igraph::as_data_frame() %>% 
  add_count(from, to)
) %>% 
  select(from, to, n)

#> # A tibble: 23,473 x 3
#>    from  to        n
#>    <chr> <chr> <int>
#>  1 BGR   JFK       2
#>  2 BGR   JFK       2
#>  3 BOS   EWR      10
#>  4 ANC   JFK       1
#>  5 JFK   ANC       1
#>  6 LAS   LAX      20
#>  7 MIA   JFK      10
#>  8 EWR   ANC       1
#>  9 BJC   MIA       1
#> 10 MIA   BJC       1
#> # ... with 23,463 more rows

...结果为整数; manualish_count$n包含 <int>埃格斯。

使用 igraph , 乍一看似乎一切都很好......

(ig_count <- count_multiple(USairports)) %>% head(10)
#>  [1]  2  2 10  1  1 20 10  1  1  1

...但实际上有分数:

ig_count[ig_count %% 1 != 0]
#>  [1] 0.5 0.5 0.5 0.5 0.5 0.5 0.5 1.5 1.5 1.5 1.5 0.5 1.5 1.5 0.5 0.5 0.5
#> [18] 0.5 1.5 1.5 1.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5
#> [35] 0.5

我是不是误会了count_multiple()的用途或使用不当?

igraph_version()
#> [1] "1.2.2"

最佳答案

这是因为 count_multiple 如何处理循环(自边)。

ig_count <- count_multiple(USairports)
x <- which(ig_count %% 1 != 0)

E(USairports)[x]

#[1] HOM->HOM FYU->FYU OME->OME ANI->ANI KLL->KLL WFB->WFB RIC->RIC DEN->DEN
#[9] BLD->BLD BLD->BLD BLD->BLD DCA->DCA DEN->DEN DEN->DEN MCI->MCI SSB->SSB
#[17] MIA->MIA KEH->KEH LKE->LKE LKE->LKE LKE->LKE LPS->LPS VGT->VGT DET->DET
#[25] CID->CID CLE->CLE JFK->JFK LGA->LGA MKE->MKE ORD->ORD PHL->PHL GRR->GRR
#[33] MEM->MEM JNU->JNU MSP->MSP

底层的 c 例程 igraph_count_multiple 明确地将边数除以 2 for 循环。

 /* for loop edges, divide the result by two */
    if (to == from) VECTOR(*res)[i] /= 2;

你可以通过只计算非循环的倍数来避免这种情况

ig_count2 <- count_multiple(simplify(USairports, remove.multiple = FALSE, remove.loops=TRUE)) 

ig_count2[1:10]
#[1]  2  2 10  1  1 20 10  1  1  1

which(ig_count2 %% 1 != 0)
#integer(0)

关于r - 关于 igraph::count_multiple() 的说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52011711/

相关文章:

python - 如何读取边缘列表以制作 scipy 稀疏矩阵

r - 允许R igraph中的箭头大小与边缘宽度匹配的技巧

r - 根据度将属性添加到边缘列表

python - 如何使用归一化互信息评估 python 中 igraph 的重叠社区

regex - 在 R 中使用 gsub 在两个斜杠之间切出字符

r - 在列表上使用 purrr 在不同的列上进行变异

Rcpp代理模型和R内存分配

r - 将嵌套的for循环转换为R中的并行

python - 安装 Python igraph 的问题

R:在混合模型上使用引导预测