Chapter 30 NETWORK VIS
網絡視覺化其實已經有非常好的簡介和指南。但在此補充一些常用的網絡視覺化參數
30.1 Generating networks
30.1.1 Random network
g <- barabasi.game(500, directed = T)
message("\n(V, E, Reciprocity, nComponent)\n",
length(V(g)), "\t",
length(E(g)), "\t",
sprintf("%.3f\t", reciprocity(g)),
count_components(g, mode = "weak")
)
l <- layout.fruchterman.reingold(g)
# l <- layout_with_kk(g)
# l <- layout_in_circle(g)
par(mar = c(0,0,0,0) + 0.1)
plot(g,
layout = l,
vertex.color = rgb(1, 1, 0, 0.2),
# vertex.color = factor(V(g)$blocked),
vertex.size = 3,
# vertex.size = sqrt(V(g)$degree)*3,
vertex.frame.color= rgb(0, 0, 0, 0.5),
# vertex.label = V(g)$display,
# vertex.label = str_sub(V(g)$name, 1, 10),
vertex.label.cex = 0.6,
vertex.label.color = rgb(0, 0, 0, 0.7),
vertex.label.family = 'Heiti TC Light',
edge.curved = 0.1,
edge.arrow.size = 0.1,
# edge.width = sqrt(E(g)$weight),
# edge.color = E(g)$year,
# edge.color = E(g)$weight,
edge.color = "#4169E1",
# edge.color = E(g)$color,
# edge.label = E(g)$weight,
# edge.label = E(g)$year,
edge.label.cex = 0.4,
edge.label.color = rgb(1, 0, 0)
)
30.1.2 Random network
rg <- sample_gnm(length(V(g)), length(E(g)), directed=T)
message("\n(V, E, Reciprocity, nComponent)\n",
length(V(rg)), "\t",
length(E(rg)), "\t",
sprintf("%.3f\t", reciprocity(rg)),
count_components(rg, mode = "weak")
)
l <- layout.fruchterman.reingold(rg)
par(mar = c(0,0,0,0) + 0.1)
plot(rg,
layout = l,
vertex.color = rgb(1, 1, 0, 0.2),
vertex.size = 3,
vertex.frame.color= rgb(0, 0, 0, 0.5),
vertex.label.cex = 0.6,
vertex.label.color = rgb(0, 0, 0, 0.7),
vertex.label.family = 'Heiti TC Light',
edge.curved = 0.1,
edge.arrow.size = 0.1,
edge.color = "#4169E1",
edge.label.cex = 0.4,
edge.label.color = rgb(1, 0, 0)
)
30.2 Retrieve Top3 Components
components <- igraph::clusters(rg, mode="weak")
biggest_cluster_id <- which.max(components$csize)
# which.max(components$csize)
# components$csize
# biggest_cluster_id
top3_break <- sort(unique(components$csize), decreasing = T)[3]
biggest_cluster_id <- which(components$csize >= top3_break)
vert_ids <- V(rg)[components$membership %in% biggest_cluster_id]
rg <- igraph::induced_subgraph(rg, vert_ids)
message("\n(V, E, Reciprocity, nComponent)\n",
length(V(rg)), "\t",
length(E(rg)), "\t",
sprintf("%.3f", reciprocity(rg))
)
30.2.1 Visualize again
l <- layout.fruchterman.reingold(rg)
par(mar = c(0,0,0,0) + 0.1)
plot(rg,
layout = l,
vertex.color = rgb(1, 1, 0, 0.2),
vertex.size = 3,
vertex.frame.color= rgb(0, 0, 0, 0.5),
vertex.label.cex = 0.6,
vertex.label.color = rgb(0, 0, 0, 0.7),
vertex.label.family = 'Heiti TC Light',
edge.curved = 0.1,
edge.arrow.size = 0.1,
edge.color = "#4169E1",
edge.label.cex = 0.4,
edge.label.color = rgb(1, 0, 0)
)
30.3 Motif visualization and analysis
30.3.1 Motif type
library(igraph)
par(mfrow=c(4,4), mai= rep(0.2, 4))
for(i in 0:15){
g1 <- graph_from_isomorphism_class(3, i)
plot(g1,
vertex.color = "gold",
vertex.size = 20,
# vertex.size = (V(g)$nTweets)^(1/3)+1,
vertex.frame.color= "black",
vertex.label = NA,
edge.color = "black",
edge.arrow.size = 0.5)
title(i, line=-3, adj=0.4 ,col.main="royalblue")
}
30.3.3 Generate motives
barabas_motif <- function(e){
g <- barabasi.game(e, directed = T)
vec <- motifs(g, 3) %>% replace_na(0)
for(i in 1:99){
g <- barabasi.game(e, directed = T)
tmp <- motifs(g, 3) %>% replace_na(0)
vec <- vec + tmp
}
vec <- vec / 100
writeLines(as.character(vec), sep = "\t")
}
random_net_motif <- function(v, e){
g <- sample_gnm(v, e, directed=T)
vec <- motifs(g, 3) %>% replace_na(0)
for(i in 1:99){
g <- sample_gnm(v, e, directed=T)
tmp <- motifs(g, 3) %>% replace_na(0)
vec <- vec + tmp
}
vec <- vec / 100
writeLines(as.character(vec), sep = "\t")
}
## 0 0 245.78 0 490.12 0.87 247.04 0.77 0 0.78 0 0.36 0.01 0 0 0
## 0 0 2517.01 0 459.54 0 0 0 0 0 0 0 0 0 0 0