#'
#' Calculate t-Distributed Stochastic Neighbor Embedding in CYT
#'
#' @name runTSNE
#'
#' @param object a CYT object
#' @param dims integer, Output dimensionality (default: 2)
#' @param initial_dims integer. the number of dimensions that should
#' be retained in the initial PCA step (default: 50). See \code{\link[Rtsne]{Rtsne}}
#' @param perplexity numeric. Perplexity parameter. See \code{\link[Rtsne]{Rtsne}}
#' @param theta numeric. Speed/accuracy trade-off (increase for less accuracy),
#' set to 0.0 for exact TSNE (default: 0.5). See \code{\link[Rtsne]{Rtsne}}
#' @param check_duplicates logical. Checks whether duplicates are present.
#' It is best to make sure there are no duplicates present and set this
#' option to FALSE, especially for large datasets (default: TRUE).
#' See \code{\link[Rtsne]{Rtsne}}
#' @param verbose logical. Whether to print calculation progress.
#' @param pca,max_iter,is_distance,Y_init,pca_center,pca_scale See \code{\link[Rtsne]{Rtsne}}
#' @param ... Parameters passing to \code{\link[Rtsne]{Rtsne}} function
#'
#' @import Rtsne
#' @seealso \code{\link[Rtsne]{Rtsne}}
#' @return A CYT object
#'
#' @references
#' Maaten, L. Van Der, 2014. Accelerating t-SNE using Tree-Based
#' Algorithms. Journal of Machine Learning Research, 15, p.3221-3245.
#'
#' van der Maaten, L.J.P. & Hinton, G.E., 2008. Visualizing High-Dimensional
#' Data Using t-SNE. Journal of Machine Learning Research, 9, pp.2579-2605.
#'
#' @export
#'
#' @examples
#'
#' cyt.file <- system.file("extdata/cyt.rds", package = "CytoTree")
#' cyt <- readRDS(file = cyt.file)
#'
#' cyt <- runTSNE(cyt, dims = 2, verbose = TRUE)
#' cyt <- runTSNE(cyt, dims = 2, perplexity = 20, verbose = TRUE)
#'
#'
#'
runTSNE <- function(object, dims = 2, initial_dims = 50, perplexity = 30,
theta = 0.5, check_duplicates = TRUE, pca = TRUE, max_iter = 1000,
verbose = FALSE, is_distance = FALSE, Y_init = NULL,
pca_center = TRUE, pca_scale = FALSE,
...) {
# tSNE calculation
if (verbose) message(Sys.time(), " Calculating tSNE.")
if (length(which(object@meta.data$dowsample == 1)) < 10) stop(Sys.time, " Not enough cells, please run processingCluster and choose correct downsampleing.size paramter. ")
mat <- object@log.data[which(object@meta.data$dowsample == 1), object@markers.idx]
tsne.obj <- Rtsne(as.matrix(mat),
dims = dims, initial_dims = initial_dims, perplexity = perplexity,
theta = theta, check_duplicates = check_duplicates, pca = pca, max_iter = max_iter,
verbose = FALSE, is_distance = is_distance, Y_init = Y_init,
pca_center = pca_center, pca_scale = pca_scale,
...)
object@tsne.value <- tsne.obj$Y
colnames(object@tsne.value) <- paste0("tSNE_", seq_len(ncol(tsne.obj$Y)))
rownames(object@tsne.value) <- rownames(mat)
if (verbose) message(Sys.time(), " Calculating tSNE completed. ")
return(object)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.