R/testSingleVarianceComponent.R

Defines functions testSingleVarianceComponent

## a function that tests a variance component (e.g. genetic relatedness, for testing heritability)
## using the likelihood ration test.
testSingleVarianceComponent <- function(nullmod, varCompName, covMatList, group.idx = NULL, AIREML.tol = 1e-6, max.iter = 100, drop.zeros = TRUE, verbose = TRUE){

	if (nullmod$model$hetResid & is.null(group.idx)) stop("missing group indices group.idx")

	ind.test <- match(varCompName, names(covMatList))


	if (length(covMatList) == 1){
		nullmod.noVarComp <- .fitNullModel(nullmod$outcome, X = nullmod$model.matrix, covMatList = NULL,
				group.idx = group.idx, family = nullmod$model$family$family, start = NULL,
				AIREML.tol = AIREML.tol, max.iter= max.iter, drop.zeros = drop.zeros, verbose = verbose)

	} else{
		nullmod.noVarComp <- .fitNullModel(nullmod$outcome, X = nullmod$model.matrix, covMatList = covMatList[-ind.test],
				group.idx = group.idx, family = nullmod$model$family$family, start = nullmod$varComp,
				AIREML.tol = AIREML.tol, max.iter= max.iter, drop.zeros = drop.zeros, verbose = verbose)
		}




	test.stat <- -2*(nullmod.noVarComp$logLik - nullmod$logLik)

	pval <- 0.5*.pchisq_filter_extreme(test.stat, df = length(nullmod$varComp), lower.tail = FALSE) + 0.5*.pchisq_filter_extreme(test.stat, df = length(nullmod$varComp) - 1, lower.tail = F)

	return(pval)
}
smgogarten/GENESIS documentation built on Nov. 10, 2024, 8:49 p.m.