# Export score tables to GOBNILP format
library("BiDAG")

number2binary <- function(number, noBits) {
    binary_vector <- rev(as.numeric(intToBits(number)))
    if (missing(noBits)) {
        return(binary_vector)
    } else {
        binary_vector[-(1:(length(binary_vector) - noBits))]
    }
}

parent_table <- function(n, p) {
    rbind(rep(NA, n), BiDAG:::parentlistnonempty(1:p, n))[, 1:p, drop = FALSE]
}


write_gobnilp_scores <- function(tables, adjmat, scorefile) {
    # Example:
    # library("BiDAG")
    # myscore<-scoreparameters("bge",Boston)
    # res <- iterativeMCMC(myscore, chainout = TRUE, scoreout = TRUE, MAP = MAP, verbose=FALSE) 
    # tables <- res$scoretable$tables
    # adjmat <- res$$scoretable$adjacency 
    # scorefile <- "gobnilpscores.txt"
    # print("Writing gobnilp scoretables")
    # write_gobnilp_scores(tables, adjmat, scorefile)
    # print("done")
    
    
    p <- length(tables)
    output_str <- paste0(p, "\n")
    #write(p, file = scorefile, append = FALSE)
    
    labels <- colnames(adjmat) # maybe the labels are wrong here..

    # For each node
    for (i in seq(p)) {
        n_plus1 <- length(tables[[i]])
        nscores <- n_plus1 * length(tables[[i]][[1]]) # the first plus1 table
        #write(paste(labels[i], nscores), file = scorefile, append = TRUE)
        output_str <- paste(output_str, paste(labels[i], nscores), "\n", sep="")
        
        potparents <- colnames(adjmat)[adjmat[, i] == 1]
        parenttable <- parent_table(p, length(potparents))

        # going through the plus1 table
        # First should always be included since it has no plus1 parents
        parent_scores <- tables[[i]][[1]] 
        n_parsets <- length(parent_scores) 

        for (k in seq(n_parsets)) {
            parvec <- parenttable[k, ]
            parvec <- parvec[which(!is.na(parvec))]
            str <- paste(tables[[i]][[1]][k], length(parvec))

            parents <- potparents[parvec]
            parentstr <- paste(parents, collapse = " ")
            str <- paste(str, parentstr)
            #write(str, file = scorefile, append = TRUE)
            output_str <- paste(output_str, str, "\n", sep="")
            
        }

        # The below is for the plus1 tables
        j <- 1
        for (node in seq(p)) {
            # Fix index so it matches the tables.
            # Skip the existing parents and it self
            if (adjmat[node, i] == 1 || i == node) {
                next
            }

            parent_scores <- tables[[i]][[j + 1]] # get the plus1 score table

            n_parsets <- length(parent_scores)
            plus1var <- labels[node]

            for (k in seq(n_parsets)) {
                parvec <- parenttable[k, ]
                parvec <- parvec[which(!is.na(parvec))]
                str <- paste(parent_scores[k], length(parvec) + 1, plus1var)
                parents <- potparents[parvec]
                parentstr <- paste(parents, collapse = " ")
                str <- paste(str, parentstr)

                #write(str, file = scorefile, append = TRUE)
                output_str <- paste(output_str, str, "\n", sep="")
            }
            j <- j + 1
        }
    }
    return(output_str)
}

# # Export score tables to GOBNILP format
# library("BiDAG")


# number2binary = function(number, noBits) {
#   binary_vector = rev(as.numeric(intToBits(number)))
#   if (missing(noBits)) {
#     return(binary_vector)
#   } else {
#     binary_vector[-(1:(length(binary_vector) - noBits))]
#   }
# }

# parent_table <- function(n, p) {
#   rbind(rep(NA, n), BiDAG:::parentlistnonempty(1:p, n))[, 1:p, drop = FALSE]
# }

# write_gobnilp_scores <- function(tables, adjmat, scorefile) {
#   # Example:
#   #library("BiDAG")
#   # myscore<-scoreparameters("bge",Boston)
#   #res <- iterativeMCMC(myscore, chainout = TRUE, scoreout = TRUE, MAP = MAP, verbose=FALSE) 
#   #tables <- res$scoretable$tables
#   #adjmat <- res$$scoretable$adjacency 
#   # scorefile <- "gobnilpscores.txt"
#   # print("Writing gobnilp scoretables")
#   # write_gobnilp_scores(tables, adjmat, scorefile)
#   # print("done")
#   p <- length(tables)
#   write(p, file = scorefile, append = FALSE)
  
#   labels <- colnames(adjmat) # maybe the labels are wrong here..
  
#   # For each node
#   for (i in seq(p)) {
#     n_plus1 <- length(tables[[i]])
#     nscores <- n_plus1 * length(tables[[i]][[1]]) # the first plus1 table
#     write(paste(labels[i], nscores), file = scorefile, append = TRUE)
#     potparents <- colnames(adjmat)[adjmat[, i] == 1]
        
#     parenttable <- parent_table(p, length(potparents)) #shold be bigger?

#     # going through the plus1 table
#     # First should always be included since it has no plus1 parents
#     parent_scores <- tables[[i]][[1]] 
#     n_parsets <- length(parent_scores) 

#     for (k in seq(n_parsets)) {
#       parvec <- parenttable[k, ]
#       parvec <- parvec[which(!is.na(parvec))]
#       str <- paste(tables[[i]][[1]][k], length(parvec))
      
#       parents <- potparents[parvec]
#       parentstr <- paste(parents, collapse = " ")
#       str <- paste(str, parentstr)
#       write(str, file = scorefile, append = TRUE)
#     }
    
#     # The below is for the plus1 tables
#     j = 1
#     for (node in seq(p)) {
#       # Fix index so it matches the tables.
#       # Skip the existing parents and it self
#       if(adjmat[node, i] == 1 || i ==node){
#         next
#       } 
      
#       parent_scores <- tables[[i]][[j+1]] # get the plus1 score table
#       n_parsets <- length(parent_scores)
#       plus1var <- labels[node] 
      
#       for (k in seq(n_parsets)) {
#         parvec <- parenttable[k, ]
#         parvec <- parvec[which(!is.na(parvec))]
#         str <- paste(parent_scores[k], length(parvec) + 1, plus1var)
#         parents <- potparents[parvec]
#         parentstr <- paste(parents, collapse = " ")
#         str <- paste(str, parentstr)
#         write(str, file = scorefile, append = TRUE)
#       }
#       j <- j+1
#     }
    
#   }
  
# }
