R/get_info.R

Defines functions getRotationMatrix

Documented in getRotationMatrix

#' getRotationMatrix
#'
#' Extract the rotation matrix from \code{\link{dimRedResult}} objects derived from PCA and FastICA
#'
#' The data has to be pre-processed the same way as the method does, e.g.
#' centering and/or scaling.
#'
#' @param x of type \code{\link{dimRedResult}}
#' @return a matrix
#'
#' @examples
#' dat <- loadDataSet("Iris")
#'
#' pca <- embed(dat, "PCA")
#' rot_pca <- getRotationMatrix(pca)
#' scale(getData(dat), TRUE, FALSE) %*% rot_pca - getData(getDimRedData(pca))
#'
#'
#' if(requireNamespace("fastICA", quietly = TRUE)) {
#'   ica <- embed(dat, "FastICA")
#'   rot_ica <- getRotationMatrix(ica)
#'   scale(getData(dat), TRUE, FALSE) %*% rot_ica - getData(getDimRedData(ica))
#' }
#'
#'
#' @family convenience functions
#' @export
getRotationMatrix <- function(x) {
  if(!inherits(x, "dimRedResult")) stop("x must be of type 'dimRedResult'")
  if(x@method == "PCA")     return(environment(x@apply)$rot)
  if(x@method == "PCA_L1")  return(environment(x@apply)$rot)
  if(x@method == "FastICA") return(environment(x@apply)$res$K %*% environment(x@apply)$res$W)
  stop(paste("Not implemented for", x@method))
}

Try the dimRed package in your browser

Any scripts or data that you put into this service are public.

dimRed documentation built on July 11, 2022, 5:06 p.m.