R/predict.BayesSUR.R

Defines functions predict.BayesSUR

Documented in predict.BayesSUR

#' @title predict method for class \code{BayesSUR}
#' @description
#' Predict responses corresponding to the posterior mean of the coefficients, 
#' return posterior mean of coefficients or indices of nonzero coefficients of 
#' a \code{BayesSUR} class object.
#' @name predict.BayesSUR
#'
#' @param object an object of class \code{BayesSUR}
#' @param newx Matrix of new values for x at which predictions are to be made
#' @param type Type of prediction required. \code{type="response"} gives the 
#' fitted responses; \code{type="coefficients"} returns the estimated 
#' coefficients depending on the arguments \code{beta.type} and \code{Pmax}.
#' \code{type="nonzero"} returns a list of the indices of the nonzero 
#' coefficients corresponding to the estimated latent indicator variable 
#' thresholding at \code{Pmax}
#' @param beta.type the type of estimated coefficients beta for prediction. 
#' Default is \code{marginal}, giving marginal beta estimation. If 
#' \code{beta.type="conditional"}, it gives conditional beta estimation
#' @param Pmax If \code{type="nonzero"}, it is a threshold for the estimated 
#' latent indicator variable. If \code{type="coefficients"}, 
#' \code{beta.type="conditional"} and \code{Pmax=0.5}, it gives median 
#' probability model betas. Default is 0
#' @param ... other arguments
#'
#' @return Predicted values extracted from an object of class \code{BayesSUR}. 
#' If the \code{BayesSUR} specified data standardization, the fitted values 
#' are base based on standardized data.
#'
#' @examples
#' data("exampleEQTL", package = "BayesSUR")
#' hyperpar <- list(a_w = 2, b_w = 5)
#'
#' set.seed(9173)
#' fit <- BayesSUR(
#'   Y = exampleEQTL[["blockList"]][[1]],
#'   X = exampleEQTL[["blockList"]][[2]],
#'   data = exampleEQTL[["data"]], outFilePath = tempdir(),
#'   nIter = 20, burnin = 10, nChains = 1, gammaPrior = "hotspot",
#'   hyperpar = hyperpar, tmpFolder = "tmp/"
#' )
#'
#' ## check prediction
#' predict.val <- predict(fit, newx = exampleEQTL[["blockList"]][[2]])
#'
#' @export
predict.BayesSUR <- function(object, newx, type = "response", 
                             beta.type = "marginal", Pmax = 0, ...) {
  if (length(type) > 1) {
    warning("'type' has length > 1 and only the first element will be used")
    type <- type[1]
  }
  if (!(type %in% c("response", "coefficients", "nonzero"))) {
    stop("Please specify correct 'type'!")
  }
  if (Pmax < 0 || Pmax > 1) {
    stop("Please specify correct argument 'Pmax' in [0,1]!")
  }
  if (!(beta.type %in% c("marginal", "conditional"))) {
    stop("Please specify acorrect 'beta.type'!")
  }

  if ((type %in% c("response", "coefficients")) && (Pmax > 0) && 
      (beta.type == "marginal")) {
    stop("Pmax > 0 is valid only if the arguments type='coefficients' and 
         beta.type='conditional'!")
  }

  gamma_hat <- getEstimator(object, estimator = "gamma", Pmax = Pmax, ...)
  beta_hat <- getEstimator(object, estimator = "beta", Pmax = Pmax, 
                           beta.type = beta.type, ...)

  object$output[-1] <- paste(object$output$outFilePath, 
                             object$output[-1], sep = "")
  X <- as.matrix(read.table(object$output$X, header = TRUE))
  if ("X0" %in% names(object$output)) {
    X0 <- as.matrix(read.table(object$output$X0))
  } else {
    X0 <- NULL
  }

  if (missing(newx)) {
    y.pred <- cbind(X0, X) %*% beta_hat
  } else {
    y.pred <- newx %*% beta_hat
  }

  gamma_out <- which(gamma_hat == 1, arr.ind = TRUE)
  colnames(gamma_out) <- c("predictors", "response")

  if (type == "response") {
    return(y.pred)
  }
  if (type == "coefficients") {
    return(beta_hat)
  }
  if (type == "nonzero") {
    return(gamma_out)
  }
}

Try the BayesSUR package in your browser

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

BayesSUR documentation built on Aug. 28, 2023, 5:09 p.m.