#' @rdname methylInheritanceAllResults
#'
#' @title Print a \code{methylInheritanceAllResults} object
#'
#' @method print methylInheritanceAllResults
#'
#' @description Print a \code{methylInheritanceAllResults} object
#'
#' @param x the output object from \code{mergePermutationAndObservation}
#' function, \code{runPermutationUsingRDSFile} function (when
#' \code{runObservationAnalysis} = \code{TRUE} and
#' \code{runPermutationUsingMethylKitInfo} function (when
#' \code{runObservationAnalysis} = \code{TRUE} to be printed
#'
#' @param \ldots arguments passed to or from other methods
#'
#' @return an object of class
#' \code{methylInheritanceAllResults}
#'
#' @examples
#'
#' ## Load dataset
#' data("methylInheritanceResults")
#'
#' ## Print dataset
#' print(methylInheritanceResults)
#'
#' @export
print.methylInheritanceAllResults <- function(x, ...) {
nbGenerations <- 0
if (!is.null(x$OBSERVATION$SITES)) {
nbGenerations = length(x$OBSERVATION$SITES$i2) + 1
} else if (!is.null(x$OBSERVATION$TILES)) {
nbGenerations = length(x$OBSERVATION$TILES$i2) + 1
}
nbPermutations <- 0
if (!is.null(x$PERMUTATION)) {
nbPermutations <- length(x$PERMUTATION)
}
isSites <- FALSE
result <- NULL
## Extract info about sites when present
if (!is.null(x$OBSERVATION$SITES)) {
tt <- unlist(x$OBSERVATION$SITES)
tt.names <- sapply(names(tt), function(x) {strsplit(x, "[.]")})
tt.analysis <- sapply(tt.names, function(x) {return(x[[1]])})
tt.types <- sapply(tt.names, function(x) {return(x[[2]])})
result <- data.frame(SOURCE=rep("OBSERVATION", length(tt)),
ELEMENT = rep("SITES", length(tt)),
ANALYSIS = tt.analysis, TYPE = tt.types,
RESULT=tt, stringsAsFactors = FALSE, row.names = NULL)
isSites <- TRUE
}
## Extract info about tiles when present
if (!is.null(x$OBSERVATION$TILES)) {
tt <- unlist(x$OBSERVATION$TILES)
tt.names <- sapply(names(tt), function(x) {strsplit(x, "[.]")})
tt.analysis <- sapply(tt.names, function(x) {return(x[[1]])})
tt.types <- sapply(tt.names, function(x) {return(x[[2]])})
dataTiles <- data.frame(SOURCE=rep("OBSERVATION", length(tt)),
ELEMENT = rep("TILES", length(tt)),
ANALYSIS = tt.analysis, TYPE = tt.types,
RESULT=tt, stringsAsFactors = FALSE,
row.names = NULL)
if (isSites) {
result <- rbind(result, dataTiles)
} else {
result <- dataTiles
}
}
# Print title before printing the content of the object
cat("Permutation Analysis\n\n")
cat("Number of Generations: ", nbGenerations, "\n")
cat("Number of Permutations: ", nbPermutations , "\n\n")
cat("Observation Results: \n")
if (!is.null(result)) {
print.data.frame(result)
} else {
cat("\tNo observation result.")
}
invisible(x)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.