-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.R
executable file
·61 lines (53 loc) · 2.04 KB
/
main.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
rm(list = ls())
setwd("./Downloads/a3/")
# --------------- Function Defintion -----------------
### convert inverse covariance matrix to links
wi2link <- function(mat) {
mat <- abs(mat)
diag(mat) <- 0
min <- min(mat)
max <- max(mat)
links <- data.frame(from = NA, to = NA, weight = NA)
for (i in 1:nrow(mat)) {
for (j in 1:ncol(mat)) {
if (mat[i,j] != 0 & i != j) {
links <- rbind(links, c(i-1,j-1,range01(mat[i,j],min,max)))
}
}
}
return(links[-1,])
}
### scale to range [0,1]
range01 <- function(var, min, max) {
res <- (var-min)/(max-min)
return(res)
}
# ---------------- Prepare Links -----------------------
nodes <- read.table(file = "./Documents/github/fp-jyfeather/AAL_Yan.csv", sep = ",", header = T)
dat.org <- read.table(file = "./Documents/github/fp-jyfeather/PET_AD.csv", sep = ",", header = T)
dat.nodes <- dat.org[,match(nodes$name, colnames(dat.org))]
library(glasso)
res.wi <- glasso(s = cov(dat.nodes), rho = 0.003)$wi
res.links <- wi2link(res.wi)
res.links <- res.links[which(res.links$weight>=0.6),]
dim(res.links)
fileConn <- file("./Downloads/temp.csv", "w")
for (k in 1:nrow(res.links)) {
write(paste("{\"source\":",res.links[k,1],",\"target\":",res.links[k,2],",\"value\":",round(res.links[k,3],2),"}", sep = ""), fileConn, append = T)
}
close(fileConn)
# --------------- networkD3 Visualization --------------------
library(networkD3)
vis <- forceNetwork(Nodes = nodes, Links = res.links,
Source = "from", Target = "to",
Value = "weight", NodeID = "name",
Group = "region", zoom = TRUE)
saveNetwork(vis, file = "main.html")
# -------------- Prepare Coordinates -------------------
dat.cord <- read.table(file = "./Documents/github/fp-jyfeather/BrainRegions.csv", sep = ";")
dat.cord <- dat.cord[match(nodes$name, colnames(dat.org)),]
fileConn <- file("./Downloads/temp.csv", "w")
for (k in 1:nrow(dat.cord)) {
write(paste(",\"x\":",dat.cord[k,4],",\"y\":",dat.cord[k,5],",\"z\":",dat.cord[k,6],sep = ""), fileConn, append = T)
}
close(fileConn)