#################################################
#################################################
##  plot.integrals:
##    Function that generates oracle influence measure
##    plots, coloring hubs and non-hubs differently.
##
##  INPUTS
##    eig   : object eigen(M) of a covariance/correlation 
##              matrix M.
##    main  : title of plot.
##    
##  OUTPUT
##    .inf_meas_curve :
##            Matrix where ith-row corresponds to influence
##            measure curve for i-th variable in the matrix M.
plot.integrals <- function(eig, main, threshold = NULL) {
  p <- length(eig$values)
  if(is.null(threshold)) threshold = sqrt(p)
  
  .inf_meas_curve <- matrix(rep(0, p * p), ncol = p)
  .inf_meas_curve[, 1] <- eig$vectors[, p]^2
  for(.i in 2:p){
    .inf_meas_curve[, .i] <- .inf_meas_curve[, .i - 1] + eig$vectors[, p - .i + 1]^2
  }
  
  ## Plot of integrals
  plot(c(0, 0), col = "white",
       xlim = c(0, p),
       ylim = c(0, 1),
       main = main,
       xlab = "No. of Eigenvectors",
       ylab = "Influence Measure Value")
  for (.j in p:1) {
    lines(x = 1:p, y = .inf_meas_curve[.j, ], col = cbPalette[1])
  }
  abline(v = threshold, col = "red")
  
  return(.inf_meas_curve)
}
