############################################################
############################################################
## Setup environment + load prior objects


library(e1071)
library(magrittr)
library(tidyverse)
library(plot.matrix)

## created_data <- TRUE  ------> To load pre-runned experiments.
## created_data <- FALSE ------> Re-run analysis.
created_data <- FALSE

p_init <- 400
ctype <- "cor"
subfolder_plots <- paste0(getwd(),"/p_", p_init, "_", ctype, "/")

if (!dir.exists(subfolder_plots)) {
  dir.create(subfolder_plots)
}

if(created_data) {
  ## Load pre-trained GLASSO + HWGL models
  load(paste0("W26_Data4_p", p_init, "_", ctype, "s.RData"))
  
} else {
  ## Load environment to train HWGL and GLASSO models.
  load(paste0("W26_Data2_p", p_init, "_", ctype, "s.RData"))
  created_data <- FALSE
}
  

eigen(cor_luad)$values[p]
eigen(cor_lusc)$values[p]

############################################################
############################################################
############################################################
############################################################
############################################################
############################################################
## GLASSO


if(!created_data) {
  
  ## GLASSO: lusc
  library(glasso)
  library(plot.matrix)
  source("src/101_GLASSO_BIC.R")
  
  #####################################
  ## Fitting GLASSO on LUSC data
  rho_length  <- 50
  rholist     <- 10^(seq(3, 2, length.out = rho_length))
  p           <- ncol(cor_lusc)
  glasso_lusc  <- glassopath(cor_lusc, rholist = rholist)
  
  dim(glasso_lusc$wi)
  
  BIC_vals_lusc <- numeric(rho_length)
  for (i in 1:rho_length) {
    sigmaHat <- cor_lusc
    precMatHat <- glasso_lusc$wi[, , i]
    n <- nrow(LUSC_mat_lt)
    p <- p
    
    BIC_vals_lusc[i] <- .BICemp(
      sigmaHat = cor_lusc, 
      precMatHat = glasso_lusc$wi[, , i],
      n = n,
      p = p)
  }
  
  
  opt_ind_lusc <- which.min(BIC_vals_lusc)
  opt_rho_lusc <- rholist[opt_ind_lusc]
  
  .thetaHat_lusc <- glasso_lusc$wi[, , opt_ind_lusc]
  
  
  
  #####################################
  ## Fitting GLASSO on LUAD data
  rho_length  <- 50
  rholist     <- 10^(seq(2, 1, length.out = rho_length))
  p           <- ncol(cor_luad)
  glasso_luad <- glassopath(cor_luad, rholist = rholist)
  
  dim(glasso_luad$wi)
  
  BIC_vals_luad <- numeric(rho_length)
  for (i in 1:rho_length) {
    n <- nrow(LUAD_mat_lt)
    BIC_vals_luad[i] <- .BICemp(
      cor_luad, 
      glasso_luad$wi[, , i],
      n = n,
      p = p)
  }
  opt_ind_luad <- which.min(BIC_vals_luad)
  opt_rho_luad <- rholist[opt_ind_luad]
  
  .thetaHat_luad <- glasso_luad$wi[, , opt_ind_luad]
  
}

#####################################
## Visualize BIC to verify model fits.
png(filename = paste0(subfolder_plots, "p", p_init, "_", ctype,  "_GL_bic.png"), 
    width = 600, height = 300)
par(mfrow = c(1,2))
plot(BIC_vals_luad, main = "LUAD: BIC")
plot(BIC_vals_lusc, main = "LUSC: BIC")
dev.off()



############################################################
############################################################
############################################################
############################################################
############################################################
############################################################
## HWGLASSO

if(!created_data) {
  
  source("src/021_Method_HWGLASSO.R")
  
  #####################################
  ## Fitting HWGLASSO on LUSC data
  rho_length <- 20
  rholist     <- 10^(seq(-1, -2, length.out = rho_length))
  #rholist     <- 10^(seq(-1.5, -2.5, length.out = rho_length))
  hwgl_lusc <- BIChwglasso(
    mat = cor_lusc, rho = rholist,
    p = p, n = nrow(LUSC_mat_lt),
    maxit = 200, penalize.diagonal = TRUE)
  
  #####################################
  ## Fitting HWGLASSO on LUAD data
  rholist     <- 10^(seq(0, -1, length.out = rho_length))
  #rholist     <- 10^(seq(-1, -2, length.out = rho_length))
  hwgl_luad <- BIChwglasso(
    mat = cor_luad, rho = rholist,
    p = p, n = nrow(LUAD_mat_lt),
    maxit = 200, penalize.diagonal = TRUE)
  
}


#####################################
## Visualizing BIC to verify fit.
png(filename = paste0(subfolder_plots, "p", p_init, "_", ctype,  "_HWGL_bic.png"), 
    width = 600, height = 300)
par(mfrow = c(1,2),
    oma = c(0, 0, 3, 0))

plot(hwgl_lusc$BIC, main = "HWGL BIC: LUSC")
plot(hwgl_luad$BIC, main = "HWGL BIC: LUAD")
dev.off()




##############################################
##############################################
##############################################
## Visualizing hub information from HWGLASSO


png(filename = paste0(subfolder_plots, "p", p_init, "_", ctype,  "_degs.png"), 
    width = 500, height = 500)
par(mfcol = c(2, 2),
    oma = c(0, 0, 3, 0))


l1glhubs_luad <- .thetaHat_luad %>%
  {. - diag(diag(.))} %>% 
  abs() %>%
  apply(1, sum) %T>%
  plot(col =  col,
       pch = 19,
       main = "GLASSO LUSC: L1 degree")

l1glhubs_lusc <- .thetaHat_lusc %>% 
  {. - diag(diag(.))} %>% 
  abs() %>%
  apply(1, sum) %T>%
  plot(col = col,
       pch = 19,
       main = "GLASSO LUSC: L1 degree")

l1hwglhubs_luad <- hwgl_luad$optimal.model$wi %>%
  {. - diag(diag(.))} %>% 
  abs() %>%
  apply(1, sum) %T>%
  plot(col = col,
       pch = 19,
       main = "HWGLASSO LUAD: L1 degree")


l1hwglhubs_lusc <- hwgl_lusc$optimal.model$wi %>% 
  {. - diag(diag(.))} %>% 
  abs() %>%
  apply(1, sum) %T>%
  plot(col =  col,
       pch = 19,
       main = "HWGLASSO LUSC: L1 degree")

dev.off()


##############################################
##############################################
##############################################
## Nice Visualization.

deg_style_plot <- function(
    deg_vals, log = FALSE, clength = 4000,
    xlab = "Influence Measure",
    main = "Log-Influence Measure",
    seed = 10,
    include.hubs = TRUE,
    hubset = c(62,64),
    names = NULL) {
  
  p <- length(deg_vals)
  rbPalweights <- colorRampPalette(c("orange","red","black"))
  colorweights <- rbPalweights(clength)
  
  degthr <- mean(deg_vals) + 2 * sd(deg_vals)
  
  xmax <- 1.4 * max(deg_vals)
  xlim <- c(0, xmax)
  
  set.seed(seed)
  order <- sample(1:p, p, FALSE)
  
  ## create empty plot
  plot(c(0,0), col = "white",
       xlim = xlim,
       ylim = c(0,p),
       xlab = xlab,
       yaxt = "n",
       ylab = "",
       main = main)
  title(ylab = "Gene Index", line = 1, cex.lab = 1.2)
  #segments(x0 = degthr, y0 = -30, y1 = p + 30,
  #         col = "red")
  #text(x = imthr, y = 390,
  #    pos = 4,
  #    cex = 1,
  #    col = "red",
  #    labels = "JIC-HD \n Threshold")
  ## Add gradient bars per variable
  for(.ell in 1:p){
    .w = deg_vals[.ell]
    .wlog = deg_vals[.ell]
    .wlength = floor(clength * .wlog / xmax) + 1
    .wfloor =  (xmax * .wlength / clength) 
    
    ## 4nd try:
    points(x = seq(0, .wfloor , length.out = .wlength),
           y = rep(order[.ell], .wlength),
           pch = 19, cex = 0.1,
           col = colorweights[1:.wlength])
  }
  
  
  if (include.hubs) {
    for (.hub in hubset) {
      ## Add the name of the hubs individually:
      .wlog <- deg_vals[.hub]
      print(c(.wlog, order[.hub], names[.hub]))
      text(x = 1.05 * .wlog , y = order[.hub] , pos = 4,
           labels = names[.hub],
           cex = 1.1,
           col = "black")
    }
  }
}

png(filename = paste0(subfolder_plots, "p", p_init, "_", ctype,  "_degs.png"), 
    width = 500, height = 500)
par(mfrow = c(2, 2),
    mar = c(4, 2, 4, 2.5),
    oma = c(0, 0, 3, 0))
deg_style_plot(
  l1glhubs_luad, clength = 200,
  xlab = "L1-Connectivity Degree",
  main = "GLASSO LUAD: L1 degree",
  seed = 10,
  include.hubs = FALSE,
  names = NULL)
deg_style_plot(
  l1glhubs_lusc, clength = 200,
  xlab = "L1-Connectivity Degree",
  main = "GLASSO LUSC: L1 degree",
  seed = 10,
  include.hubs = FALSE,
  names = NULL)
deg_style_plot(
  l1hwglhubs_luad, clength = 200,
  xlab = "L1-Connectivity Degree",
  main = "HWGLASSO LUAD: L1 degree",
  seed = 10,
  include.hubs = TRUE,
  names = colnames(cor_luad))
deg_style_plot(
  l1hwglhubs_lusc, clength = 200,
  xlab = "L1-Connectivity Degree",
  main = "HWGLASSO LUSC: L1 degree",
  seed = 10,
  include.hubs = TRUE,
  names = colnames(cor_luad))
mtext("Gene Connectivity: LUAD vs. LUSC",
      outer = TRUE,
      side = 3,
      cex = 2)
dev.off()



############################################################
############################################################
############################################################
############################################################
## Creating neighborhood plots for HWGLASSO:

library(igraph)

colinds <- function(p) {
  matrix(rep(1:p, p), ncol = p, byrow = TRUE) %>%
    return()
}
rowinds <- function(p) {
  matrix(rep(1:p, p), ncol = p, byrow = FALSE) %>%
    return()
}

################################
################################
## Generating hub neighborhoods:
gene_names <- colnames(cor_luad)

p <- ncol(hwgl_lusc$optimal.model$wi)
net_lusc <- hwgl_lusc$optimal.model$wi %>%
  #{(abs(.) > 1e-4) * (colinds(p) %in% c(62,64) | rowinds(p) %in% c(62,64))} %>%
  {(abs(.) > 10^(-3.8)) * (colinds(p) %in% c(62,64) | rowinds(p) %in% c(62,64))} %>%
  {. - diag(diag(.))} %>%
  graph_from_adjacency_matrix()
Isolated_lusc <- which(degree(net_lusc) == 0)
connected <- which(degree(net_lusc) != 0)
connected_lusc <- gene_names[connected]

p <- ncol(hwgl_luad$optimal.model$wi)
net_luad <- hwgl_luad$optimal.model$wi %>%
  #{(abs(.) > 10^(-3.7)) * (colinds(p) %in% c(62,64) | rowinds(p) %in% c(62,64))} %>%
  {(abs(.) > 10^(-3.5)) * (colinds(p) %in% c(62,64) | rowinds(p) %in% c(62,64))} %>%
  {. - diag(diag(.))} %>%
  graph_from_adjacency_matrix()
Isolated_luad <- which(degree(net_luad) == 0)
connected <- which(degree(net_luad) != 0)
connected_luad <- gene_names[connected]


connected_joint <- intersect(connected_luad, connected_lusc)
#isolated_joint <- unique(Isolated_luad, Isolated_lusc)
length(connected_luad)
length(connected_lusc)
length(connected_joint)

net_luad2 <- delete_vertices(net_luad, Isolated_luad)
net_lusc2 <- delete_vertices(net_lusc, Isolated_lusc)


V(net_lusc2)$color <- rep("orange", length(connected_lusc))
V(net_lusc2)$color[connected_lusc %in% c("SFTPA1","SFTPA2")] <- rep("red", 2)
V(net_lusc2)$size <- 7.5
V(net_lusc2)$label.cex <- ifelse(connected_lusc %in% c("SFTPA1","SFTPA2"), 1.2, 0.9)
V(net_lusc2)$label <- ifelse(connected_lusc  %in% connected_joint,  connected_lusc, "")
V(net_lusc2)$frame.color <- "white"
E(net_lusc2)$arrow.mode <- 0



V(net_luad2)$color <- rep("orange", length(connected_luad))
V(net_luad2)$color[connected_luad %in% c("SFTPA1","SFTPA2")] <- rep("red", 2)
V(net_luad2)$size <- 7.5
V(net_luad2)$label.cex <- ifelse(connected_luad %in% c("SFTPA1","SFTPA2"), 1.2, 0.9)
V(net_luad2)$label <- ifelse(connected_luad  %in% connected_joint,  connected_luad, "")
V(net_luad2)$frame.color <- "white"
E(net_luad2)$arrow.mode <- 0


################################
################################
## Generating network plots:
png(filename = paste0(subfolder_plots, "p", p_init, "_", ctype, "_hwgl_hubs.png"), 
    width = 600, height = 300)
par(mfrow = c(1,2), mar = c(0,0,0,0))
set.seed(54)
lw <- layout_with_fr(net_lusc2, niter = 1000)
plot(net_lusc2, layout = -lw, ylim = c(-1.3, 1))
text(x = 0, y = -1.15, "LUSC", cex = 2)
#set.seed(13)
set.seed(34)
lw <- layout_with_fr(net_luad2, niter = 1015)
plot(net_luad2, layout = lw, ylim = c(-1.3, 1))
text(x = 0, y = -1.15, "LUAD", cex = 2)
dev.off()



## Save environment
if(!created_data) {
  rm(created_data)
  save.image(paste0("W26_Data4_p", p_init, "_", ctype, "s.RData"))
}
rm(list = ls())


















