首页 > 解决方案 > 根据属性着色的 igraph 边缘消失

问题描述

我想根据另一个边缘属性在 igraph 中为网络的边缘着色。

这是我所做的:

vector <- c("a","b","b","d","b","c","c","a")
field <- c("friend","friend","good friend","archenemy")

g <- graph(vector, directed = FALSE)
E(g)$status <- field

library(RColorBrewer)
color = grDevices::colors()[grep('gr(a|e)y', grDevices::colors(), invert = 
T)]
n <- length(unique(field))

col=sample(color, n)
sec=unique(field)
coloring <- as.list(setNames(col,sec))

E(g)$color <- coloring[E(g)$status]

在这里我得到一个错误,或者根本没有边缘。

plot(g,edge.color=E(g)$color)

标签: rcolorsnetwork-programmingigraph

解决方案


这对我有用。您的原始代码列出了g. 检查E(g)$color

library(igraph)
library(RColorBrewer)
color = grDevices::colors()[grep('gr(a|e)y', grDevices::colors(), invert = T)]

vector <- c("a","b","b","d","b","c","c","a")
field <- c("friend","friend","good friend","archenemy")
####
g <- graph(vector, directed = FALSE)
E(g)$status <- field

n <- length(unique(field))
col=sample(color, n)

coloring <- col[factor(field)]
E(g)$color <- coloring

plot(g)

推荐阅读