R/condiNumber.R

Defines functions condiNumber.maxLik condiNumber.default condiNumber

Documented in condiNumber condiNumber.default condiNumber.maxLik

### condiNumber: print matrix' condition number adding columns one by one.
### In this way user may investigate the which columns cause problems with singularity

condiNumber <- function(x, ...)
    UseMethod("condiNumber")

condiNumber.default <- function(x, exact=FALSE, norm=FALSE,
                                printLevel=print.level, print.level=1, 
   digits = getOption( "digits" ), ... ) {
   ## x:  a matrix, condition number of which are to be printed
   ## exact: whether the condition number have to be exact or approximated (see 'kappa')
   ## norm: whether to normalise the matrix' columns.
   ## printLevel: whether to print the condition numbers while calculating.  Useful for interactive testing. 
   savedDigits <- getOption("digits")
   options( digits = digits )
   if(dim(x)[2] > dim(x)[1]) {
      warning(paste(dim(x)[1], "rows and", dim(x)[2], "columns, use transposed matrix"))
      x <- t(x)
   }
   cn <- numeric(ncol(x))
    if(norm) {
                                        # Now normalise column vectors
       x <- apply(x, 2, FUN=function(v) v/sqrt(sum(v*v)))
    }
    for(i in seq(length=ncol(x))) {
        m <- x[,1:i]
        cn[i] <- kappa(m, exact=exact)
        if(printLevel > 0)
            cat(colnames(x)[i], "\t", cn[i], "\n")
    }
   names(cn) <- colnames(x)
   options( digits = savedDigits )
   invisible(cn)
}

condiNumber.maxLik <- function(x, ...)
    condiNumber.default( x = hessian(x)[activePar(x), activePar(x),drop=FALSE],
       ... )

Try the maxLik package in your browser

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

maxLik documentation built on May 29, 2024, 2:32 a.m.