-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrandom_graph_dist.R
75 lines (58 loc) · 2.32 KB
/
random_graph_dist.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
##########################################
#For genrating random graph network file.
#Hua created.
#2016-9-23.
##########################################
require ( "igraph" )
#Plot the data read from graph file.
graph.plot <- function(links){
net <- graph_from_data_frame( d=links, directed=T )
plot(net, vertex.size=30, vertex.label.cex=2)
return (NULL)
}
#Read the graph file, return the inside data. An option to plot or not plot by specifying plot parameter.
graph.from.file <- function(input.file, plot=TRUE){
##
links <- read.table(input.file, header = FALSE, sep = '\t', quote = "", stringsAsFactors = FALSE)
colnames(links) <- c("from", "to")
##
if(plot){
graph.plot(links)
}
return (links)
}
#Compare the two graph from two files. For small examples, use plot=TRUE; for the big one, use plot=FALSE.
graph.compare <- function(file1, file2, plot=TRUE){
g1 <- graph.from.file(file1, plot=FALSE)
g2 <- graph.from.file(file2, plot=FALSE)
g1 <- g1[order(g1[,1], g1[,2]),]
g2 <- g2[order(g2[,1], g2[,2]),]
# print(g1)
# print(g2)
test <- TRUE
test <- test & (nrow(g1) == nrow(g2)) & (ncol(g1) == ncol(g2))
test <- test & (sum(g1 == g2) == nrow(g1) * ncol(g1))
if(!test){
stop("Sorry, not equal!")
}else{
#message("Congratulations!")
if(plot){
graph.plot(g1)
graph.plot(g2)
}
}
return (test)
}
#Randomly generate big graph file.
random.graph <- function(number.of.nodes = 100000, number.of.edges = 100000, min_dist, max_dist, output.file = "in_test_big.txt"){
nodes <- paste("N", seq(from=1, to=number.of.nodes), sep="")
parent.nodes <- c(nodes, nodes[sample(c(1:number.of.nodes), number.of.edges-number.of.nodes, TRUE)])
parent.nodes <- parent.nodes[sample(c(1:length(parent.nodes)), length(parent.nodes), FALSE)]
child.nodes <- c(nodes, nodes[sample(c(1:number.of.nodes), number.of.edges-number.of.nodes, TRUE)])
child.nodes <- child.nodes[sample(c(1:length(child.nodes)), length(child.nodes), FALSE)]
links <- data.frame(from = parent.nodes, to = child.nodes)
links <- unique(links)
dist <- sample(c(min_dist:max_dist), nrow(links), TRUE)
links <- cbind(links, data.frame(distance = dist))
write.table(links, output.file, append = FALSE, sep = '\t', quote = FALSE, row.names = FALSE, col.names = FALSE)
}