R/show-methods.R

# #' @include AllClasses.R
#NULL

#' Shows relevant content of a SingleCellExperiment object for a CellTrails
#' analysis
#' @param object A \code{SingleCellExperiment} object
#' @return \code{showTrajInfo} returns an invisible \code{NULL}
#' @examples
#' # Example data
#' data(exSCE)
#'
#' showTrajInfo(exSCE)
#' @import SingleCellExperiment
#' @importFrom SummarizedExperiment rowData colData
#' @importFrom igraph vcount ecount
#' @export
#' @docType methods
#' @aliases showTrajInfo,SingleCellExperiment-method
#' @author Daniel C. Ellwanger
setGeneric("showTrajInfo", function(object) standardGeneric("showTrajInfo"))
setMethod("showTrajInfo", "SingleCellExperiment", function(object){
  d <- dim(.exprs(object))
  lmarks <- "none"
  if(!is.null(.trajGraph(object))) {
    tps <- table(.trajLandmark(object, type="type"))
    lmarks <- paste0(" #Branches=", tps["B"],
                     " #Terminals=", tps["H"],
                     " #User=", tps["U"])
  }
  trajs <- ifelse(is.null(.spanForest(object)),
                  "none",
                  paste0("[Component(#Vertices,Edges)]: ",
                         paste0(seq(length(.spanForest(object))),
                                rep("(", length(.spanForest(object))),
                                unlist(lapply(.spanForest(object),
                                              function(x){paste(vcount(x),
                                                                ecount(x),
                                                                sep = ',')})),
                                rep(")", length(.spanForest(object))),
                                collapse = " "), ""))

  mse <- ifelse(is.null(trajResiduals(object)), "NA",
                format(mean(trajResiduals(object), na.rm=TRUE),
                       scientific=TRUE, digits=2))

  latspec <- ifelse(is.null(CellTrails::latentSpace(object)),
                    "none",
                    paste0(nrow(CellTrails::latentSpace(object)),
                           " samples, ",
                           ncol(CellTrails::latentSpace(object)),
                           " dimensions"))
  sts <- .prettyString(levels(states(object)))

  out <- paste0("[[ CellTrails ]] \n",
         "logcounts: ", d[1], " features, ", d[2], " samples\n",
         "Pheno data: \n",
         "  sampleNames: ", .prettyString(colnames(object)), "\n",
         "  phenoNames: ", .prettyString(phenoNames(object)), "\n",
         "Feature data: \n",
         "  featureNames: ", .prettyString(rownames(object)), "\n",
         "  rowData: ", .prettyString(colnames(rowData(object))), "\n",
         "Trajectory data: \n",
         "  trajFeatureNames: ", .prettyString(trajFeatureNames(object)), "\n",
         "  latentSpace: ", latspec, "\n",
         "  states: ", sts, "\n",
         "Trajectories: ", trajs, "\n",
         #"  states: ", .prettyString(trajectoryStates(object)), "\n",
         "  trajSampleNames: ", .prettyString(trajSampleNames(object)), "\n",
         "  trajResiduals: MSE=", mse, "\n",
         "  landmarks: ", lmarks, "\n",
         "  trajLayout: ", ifelse(is.null(trajLayout(object)),
                                  "none", "available"), "\n",
         "Trail data: \n",
         "  trailNames: ", .prettyString(trailNames(object)), "\n")
  cat(out)})
elldc/CellTrails documentation built on May 16, 2020, 4:40 a.m.