R/densityTransitionFixed.R

#' Fixed transition probability matrix
#'
#' @inherit Density
#' @param A A numeric matrix of size \emph{KxK} with rows suming to one.
#' @family Density
#' @examples
#' TransitionFixed(
#'   A = matrix(c(0.2, 0.9, 0.8, 0.1), 2, 2)
#' )
TransitionFixed   <- function(A = NULL, ordered = NULL, equal = NULL, bounds = list(NULL, NULL),
                              trunc = list(NULL, NULL), k = NULL, r = NULL, param = NULL) {
  LinkDensity("TransitionFixed", ordered, equal, bounds, trunc, k, r, param, A = A)
}

#' @keywords internal
#' @inherit explain_density
explain_density.TransitionFixed   <- function(x, print = TRUE) {
  sprintf(
    "Fixed matrix: %s.",
    matrix_to_stan(x$A)
  )
}

#' @keywords internal
#' @inherit freeParameters
freeParameters.TransitionFixed     <- function(x) { "" }

#' @keywords internal
#' @inherit fixedParameters
fixedParameters.TransitionFixed    <- function(x) { "" }

#' @keywords internal
#' @inherit getParameterNames
getParameterNames.TransitionFixed  <- function(x) { "" }

#' @keywords internal
#' @inherit is.FixedTransition
is.FixedTransition.TransitionFixed <- function(x) { TRUE }

#' @keywords internal
#' @inherit link
link.TransitionFixed <- function(x) {
  if (!(check_transition_matrix(x$A) || dim(x$A)[1] != x$K) ) {
    stop("If fixed, A must be a square matrix of size KxK with simplex rows.")
  }

  sprintf(
    "A[i] = %s[i]';",
    matrix_to_stan(x$A)
  )
}

#' @keywords internal
#' @inherit prior
prior.TransitionFixed              <- function(x) { "" }
luisdamiano/BayesHMM documentation built on May 20, 2019, 2:59 p.m.