R/is.transiogram.R

Defines functions is.transiogram

Documented in is.transiogram

is.transiogram <-
function(object) {
  if(!is(object, "transiogram")) return(FALSE)
  if(!prod(c("Tmat", "lags", "type") %in% names(object))) return(FALSE)
  if(!length(names(object)) %in% c(3, 4)) return(FALSE)
  if(!is.array(object$Tmat)) return(FALSE)
  if(diff(dim(object$Tmat)[1:2]) != 0) return(FALSE)
  if(!is.null(object$LOSE)) {
    if(!is.array(object$LOSE)) return(FALSE)
    if(diff(dim(object$LOSE)[1:2]) != 0) return(FALSE)
  }
  if(!is.numeric(object$lags)) return(FALSE)
  if(!is.character(object$type)) return(FALSE)
  if(object$type != "Empirical" && object$type != "Theoretical") return(FALSE)
  return(TRUE)
}

Try the spMC package in your browser

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

spMC documentation built on May 3, 2023, 9:13 a.m.