R/validmat.R

Defines functions validmat

Documented in validmat

validmat<-function(mat,p,tolval,tolsym,allowsingular,algorithm=c("anneal","genetic","improve","eleaps","none"))
{
#   Function validmat
#   Checks the main (covariance/total sums of squares and products)
#   matrix for size, symmetry, positive definiteness, etc.
#   To be called from other functions, not directly by the user.

# valid input?

  algorithm <- match.arg(algorithm) 
  if (!is.matrix(mat)) {
         stop("Data is missing or is not given in matrix form")}
     if (dim(mat)[1] != dim(mat)[2]) {
         mat<-cor(mat)
         warning("Data must be given as a covariance or correlation matrix. \n It has been assumed that you wanted the correlation matrix of the \n data matrix which was supplied.")
       }

# checking for symmetry in the 'total' input matrix

         maxabssym <- max(abs(mat-t(mat)))
         if (maxabssym > tolsym)
           {stop("\n The covariance/total matrix supplied is not symmetric.\n  Symmetric entries differ by up to ",maxabssym,".")}
         else if (maxabssym > .Machine$double.eps) {
              mat <-(mat+t(mat))/2
                    warning("\n The covariance/total matrix supplied was slightly asymmetric: \n symmetric entries differed by up to ",maxabssym,".\n (less than the 'tolsym' parameter).\n It has been replaced by its symmetric part.\n")
}

        eigvals <- eigen(mat,symmetric=TRUE,only.values=TRUE)$values
	repcnumb <- eigvals[p]/eigvals[1] 


  # Positive definiteness

 	if ( repcnumb < -1*tolval )
            stop("\n The covariance/correlation matrix supplied is not positive definite")
 
# checking for ill-conditioned 'total' matrix

         if (repcnumb < tolval) {    
		if (allowsingular==TRUE)  { 
			if (algorithm!="none" && (is.null(attr(mat,"KnownSing")) || attr(mat,"KnownSing")!=TRUE))  {
				if (algorithm == "eleaps") 
					warning(paste("\n The covariance/correlation matrix supplied has reciprocal condition number smaller than \n the specified threshold of ",tolval,".\n Therefore the full variable set might not have a well defined criterion value and the search \n will be restricted to subsets where correlation matrices are well conditioned.\n Setting lower values for the 'tolval' and 'maxaperr' function arguments may force more solutions, but numerical \n accuracy may be compromised.",sep=""))  
				else			
					warning(paste("\n The covariance/correlation matrix supplied has reciprocal condition number smaller than \n the specified threshold of ",tolval,".\n Therefore the full variable set might not have a well defined criterion value and the search \n will be restricted to subsets where correlation matrices are well conditioned.\n Setting lower values for the 'tolval' function argument may force more solutions, but numerical \n accuracy may be compromised.",sep=""))  

			}
        		return("singularmat")
         	}                                    
		if (allowsingular==FALSE)   	
			stop(paste("\n The covariance/correlation matrix supplied has reciprocal condition number \n smaller than the specified threshold of", tolval,".\n Suggestion 1: Setting a lower value of the 'tolval' function argument may force a solution, \n but numerical accuracy  may be compromised. \n Suggestion 2: Try a new function call after excluding  variables responsible for the (real \n or approximate) linear dependences. See help(trim.matrix) for  assistance in this respect. \n Suggestion 3: Try a well-conditioned shrinkage estimate of the covariance/correlation \n matrix instead. See the R package corpcor on CRAN."))  
	}	

        return("validmat")

}

Try the subselect package in your browser

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

subselect documentation built on April 12, 2025, 1:18 a.m.