R/dist_normal.R

Defines functions toString.bmerNormalDist

setClass("bmerNormalDist",
         representation(R.cov.inv = "matrix"),
         contains = "bmerDist")

toString.bmerNormalDist <- function(x, digits = getOption("digits"), ...) {
  if (any(diag(x@R.cov.inv) == 0)) {
    cov <- diag(1 / diag(x@R.cov.inv)^2)
    sds <- sqrt(diag(cov))
    corrs <- matrix(0, nrow(cov), ncol(cov))
  } else {
    cov <- crossprod(solve(x@R.cov.inv))
    sds <- sqrt(diag(cov))
    corrs <- diag(1 / sds) %*% cov %*% diag(1 / sds)
  }
  
  sds <- round(sds, digits)
  corrs <- round(corrs[lower.tri(corrs)], digits)
  
  if (nrow(cov) > 2L) {
    covString <- paste0("sd = c(", paste0(round(sds[1L:2L], digits), collapse = ", "),
                        ", ...), corr = c(", round(corrs[1L], digits), " ...)")
  } else if (nrow(cov) == 2L) {
    covString <- paste0("sd = c(", paste0(round(sds[1L:2L], digits), collapse = ", "),
                        "), corr = ", round(corrs[1L], digits))
  } else {
    covString <- paste0("sd = ", round(sds[1L], digits))
  }
  
  paste0("normal(", covString, ", ",
         "common.scale = ", x@commonScale, ")")
}

setMethod("getDFAdjustment", "bmerNormalDist",
  function(object) {
    if (object@commonScale == TRUE) sum(diag(object@R.cov.inv) != 0) else 0
  }
)
setMethod("getConstantTerm", "bmerNormalDist",
  function(object) {
    R.cov.inv <- object@R.cov.inv
    if (any(diag(R.cov.inv) < 0)) return(NA)
    
    nonZeroes <- diag(R.cov.inv) != 0
    rank <- sum(nonZeroes)
    
    rank * log(2 * pi) - 2.0 * sum(log(diag(R.cov.inv)[nonZeroes]))
  }
)
setMethod("getExponentialSigmaPower", "bmerNormalDist",
  function(object) { if (object@commonScale == TRUE) -2 else 0 }
)
setMethod("getExponentialTerm", "bmerNormalDist",
  function(object, beta) {
    exponential <- tcrossprod(crossprod(beta, object@R.cov.inv))[1]
    if (object@commonScale == TRUE) c(-2, exponential) else c(0, exponential)
  }
)

Try the blme package in your browser

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

blme documentation built on Jan. 6, 2021, 1:08 a.m.