R/rmnorm.R

#' rmnorm Generate random numbers from the multivariate normal distribution
#' @title Generate random numbers from the multivariate normal distribution
#' @author Based on lmf package
#' @return For n > 1 rmnorm returns a matrix of n rows of random vectors, while for n = 1 rmnorm returns a named random vector.
#' @param n the number of random vectors to be generated.
#' @param mean a vector with means of length d.
#' @param varcov a variance-covariance matrix with dimentions d * d.
#' @description rmnorm generate random numbers from a multivariate normal distribution.
#' @family Distributions
#' @examples 
#' \dontrun{
#' #Variance-covariance matrix
#' varcov <- matrix(c(2.047737e-03, 3.540039e-05, 0.0075178920, 3.540039e-05,
#' 6.122832e-07, 0.0001299661, 7.517892e-03, 1.299661e-04, 0.0276005740), ncol = 3)
#' #Set names
#' nam <- c("a", "b", "c")
#' dimnames(varcov) <- list(nam, nam)
#' #Check positive definiteness (all positive eigenvalues = positive definite)
#' eigen(varcov) $values
#' #Mean
#' mean <- c(1, 0.3, 0.5)
#' #Generate n = 1 random vector
#' rmnorm(n = 1, mean = mean, varcov = varcov)
#' #Generate n = 10 random vectors
#' rmnorm(n = 10, mean = mean, varcov = varcov)
#' #Generate n = 1 random vectors when varcov is non-positive definite
#' #Non-positive definite varcov matrix
#' varcov2 <- matrix(c(2.04e-03, 3.54e-05, 7.52e-03, 3.54e-05, 6.15e-07,
#'   1.30e-04, 7.52e-03, 1.30e-04, 2.76e-02), ncol = 3)
#'   dimnames(varcov2) <- dimnames(varcov)
#' eigen(varcov2)
#' #Random vector
#' rmnorm(n = 1, mean = mean, varcov = varcov2)
#' }
#' @export

rmnorm <- function (n = 1, mean = rep(0, d), varcov) {
  d <- if (is.matrix(varcov)) 
    ncol(varcov)
  else 1
  z <- try(matrix(rnorm(n * d), n, d) %*% chol(varcov), silent = TRUE)
  if (inherits(z, "try-error")) 
    z <- try(matrix(rnorm(n * d), n, d) %*% chol(nearPD(varcov)), 
             silent = TRUE)
  if (inherits(z, "try-error")) 
    return(rep(NA, d))
  y <- t(mean + t(z))
  if (n == 1 & !is.null(colnames(varcov))) {
    y <- c(y)
    names(y) <- colnames(varcov)
  }
  return(y)
  
}

Try the HelpersMG package in your browser

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

HelpersMG documentation built on Oct. 5, 2023, 5:08 p.m.