##############################################
############# Part 0: Functions ##############
##############################################
## BIC function for GLASSO:
.BICemp <- function(sigmaHat, precMatHat, n, p) {
  .bic <- 0
  .bic <- .bic - n * sum(log(eigen(precMatHat)$values))
  .bic <- .bic + n * Trace(precMatHat %*% sigmaHat)
  
  .edgenum = 0
  for (.i in 2:p) {
    for (.j in 1:(.i-1)) {
      .edgenum = .edgenum + (abs(precMatHat[.i, .j]) > 10^(-6))
    }
  }
  .bic <- .bic + log(n)*.edgenum
  return(.bic)
}
