inst/HighDimSY.R

#' High Dimensional SY
#'
#' @inheritParams SYS
#'
#' @return list of reduced data, projection matrix, 
#'          group variable, discrimination function, 
#'          m matrix.
#' @export
#'
#' @examples HighDimSY(iris, group = Species, targetDim = 1)
HighDimSY <- function(x, ...){
  UseMethod("HighDimSY")
}

#' @export
#' @rdname HighDimSY
#' @importFrom lazyeval expr_find
#' @importFrom lazyeval lazy_dots
HighDimSY.data.frame <- function(x, group, targetDim, ...){
  dataDftoMatrix(data = x,
                 group = expr_find(group),
                 targetDim = targetDim,
                 method = expr_find(HighDimSY.matrix),
                 .dots = lazy_dots(...))
}

#' @export
#' @rdname HighDimSY
#' @importFrom lazyeval expr_find
#' @importFrom lazyeval lazy_dots
HighDimSY.grouped_df <- function(x, targetDim, ...){
  dataDftoMatrix(data = x,
                 group = attributes(x)$vars[[1]],
                 targetDim = targetDim,
                 method = expr_find(HighDimSY.matrix),
                 .dots = lazy_dots(...))
}

#' @export
#' @rdname HighDimSY
#' @importFrom lazyeval expr_find
#' @importFrom lazyeval lazy_dots
HighDimSY.resample <- function(x, targetDim, ...){
  x <- as.data.frame(x)
  dataDftoMatrix(data = x,
                 group = attributes(x)$vars[[1]],
                 targetDim = targetDim,
                 method = expr_find(HighDimSY.matrix),
                 .dots = lazy_dots(...))
}

#' @export
#' @rdname HighDimSY
#' @importFrom stringr str_detect
#' @importFrom stringr str_replace
#' @importFrom lazyeval lazy_dots
#' @importFrom lazyeval lazy_eval
#' @importFrom sparsediscrim dqda
#' @importFrom stats cov
HighDimSY.matrix <- function(..., targetDim, svdMethod = svd){
  ls <- lazy_dots(...)
  matrix_ls <- lazy_eval(ls[str_detect(names(ls), "x.")])
  names(matrix_ls) <- str_replace(names(matrix_ls), "x.", "")
  
  
  xbar <- lapply(matrix_ls, colMeans)
  covs <- lapply(matrix_ls, cov)
  
  projectedMeanDiffs <- Reduce(cbind, lapply(xbar, function(x){
    x - xbar[[1]]
  })[-1])
  
  covsDiffs <- Reduce(cbind, lapply(covs, function(x){x - covs[[1]]})[-1])
  
  M <- cbind(projectedMeanDiffs, covsDiffs)
  
  projection <- t(do.call(svdMethod, list(M))$u[,1:targetDim])
  originalData <- Reduce(rbind, matrix_ls)
  nameVec <- as.data.frame(as.matrix(Reduce(c, mapply(function(x, y){rep(y, nrow(x))},
                                                      matrix_ls, names(matrix_ls), SIMPLIFY = FALSE))))
  
  names(nameVec) <- paste(ls$group$expr)
  reducedData <- t(projection %*% t(originalData))
  
  object <- list(reducedData = group_by_(cbind(as.data.frame(reducedData), nameVec),
                                         paste(ls$group$expr)),
                 projectionMatrix = projection,
                 group = ls$group$expr,
                 discrimFunc = expr_find(dqda),
                 M = M)
  class(object) <- "reduced"
  object
}
BenBarnard/covEstR documentation built on May 7, 2019, 7:58 a.m.