R/survregDtest.R

Defines functions survregDtest

Documented in survregDtest

#
# Test out if a distribution object found in survreg is legal.  Mostly called
#  by the survreg routine, but a user might use it when developing a new
#  distribution object
#
# Short form, returns just T or F
# Long form, returns all of the issues with the object, or T if it is ok
#
survregDtest <- function(dlist, verbose=F) {
    errlist <- NULL

    if (is.null(dlist$name)) errlist <- c(errlist, "Missing a name")
    else if (length(dlist$name) !=1 || !is.character(dlist$name))
        errlist <- c(errlist, "Invalid name")

    #
    # First case, the object is a reference to another distribution
    #
    if (!is.null(dlist$dist)) {
        if (!is.character(dlist$dist) || 
            is.null(match(dlist$dist, names(survreg.distributions))))
            errlist <- c(errlist, "Reference distribution not found")

        else {
            if (!is.function(dlist$trans))
                errlist <- c(errlist, "Missing or invalid trans component")
            if (!is.function(dlist$itrans))
                errlist <- c(errlist, "Missing or invalid itrans component")
            if (!is.function(dlist$dtrans))
                errlist <- c(errlist, "Missing or invalid dtrans component")
            }

        if (is.null(errlist)) {
            if (!all.equal(dlist$itrans(dlist$trans(1:10)), 1:10))
                errlist <- c(errlist, 
                             "trans and itrans must be inverses of each other")
            if (length(dlist$dtrans(1:10)) != 10)
                errlist <- c(errlist, "dtrans must be a 1-1 function")
            }
        }

    # Second case, the actual definition of a distribution
    else {
	# Comment out the next line, until some function uses the variance
	#if (!is.function(dlist$variance))
	#    errlist <- c(errlist, "Missing or invalid variance function")
	if (!is.function(dlist$init))
	    errlist <- c(errlist, "Missing or invalid init function")
	if (!is.function(dlist$deviance))
	    errlist <- c(errlist, "Missing or invalid deviance function")
	if (!is.function(dlist$density))
	    errlist <- c(errlist, "Missing or invalid density function")
	else {
	    if (is.null(dlist$parms))
		    temp <- dlist$density(1:10/10)
	    else    temp <- dlist$density(1:10/10, unlist(dlist$parms))
	    if (!is.numeric(temp) || !is.matrix(temp) ||
		nrow(temp) != 10 || ncol(temp) != 5)
	         errlist <- c(errlist, 
			     "Density function must return a 5 column matrix")
	    }
	
	if (!is.function(dlist$quantile))
	    errlist <- c(errlist, "Missing or invalid quantile function")
	}

    if (is.null(errlist)) T
    else if (verbose) errlist else F
    }

Try the survival package in your browser

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

survival documentation built on Aug. 14, 2023, 9:07 a.m.