From 297e3bd0939d0ce258b9a3a6b082be731fd61121 Mon Sep 17 00:00:00 2001 From: Xihao Li Date: Fri, 25 Oct 2024 14:28:36 -0400 Subject: [PATCH] STAARpipeline v0.9.7.1 --- R/fit_nullmodel.R | 21 ++++++++++----------- README.md | 2 +- 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/R/fit_nullmodel.R b/R/fit_nullmodel.R index abfb3ae..4fa13e3 100644 --- a/R/fit_nullmodel.R +++ b/R/fit_nullmodel.R @@ -82,15 +82,11 @@ fit_nullmodel <- function(fixed, data = parent.frame(), kins, use_sparse = NULL, if(use_SPA) { - # generate XW X <- obj_nullmodel$X - working <- obj_nullmodel$weights - obj_nullmodel$XW <- as.matrix(crossprod(X,obj_nullmodel$Sigma_i)) - obj_nullmodel$XXWX_inv <- as.matrix(X%*%obj_nullmodel$cov) - - obj_nullmodel$XSigma_i <- obj_nullmodel$XW - obj_nullmodel$XXSigma_iX_inv <- obj_nullmodel$XXWX_inv + # generate XSigma_i + obj_nullmodel$XSigma_i <- as.matrix(crossprod(X,obj_nullmodel$Sigma_i)) + obj_nullmodel$XXSigma_iX_inv <- as.matrix(X%*%obj_nullmodel$cov) } }else if(!inherits(kins, "matrix") && !inherits(kins, "Matrix")){ @@ -109,7 +105,7 @@ fit_nullmodel <- function(fixed, data = parent.frame(), kins, use_sparse = NULL, { X <- obj_nullmodel$X - ## generate XSigma_iX + ## generate XSigma_i obj_nullmodel$XSigma_i <- crossprod(X,obj_nullmodel$Sigma_i) obj_nullmodel$XXSigma_iX_inv <- X%*%obj_nullmodel$cov } @@ -133,7 +129,7 @@ fit_nullmodel <- function(fixed, data = parent.frame(), kins, use_sparse = NULL, { X <- obj_nullmodel$X - ## generate Sigma_i + ## generate XSigma_i obj_nullmodel$XSigma_i <- crossprod(X,obj_nullmodel$Sigma_i) obj_nullmodel$XXSigma_iX_inv <- X%*%obj_nullmodel$cov } @@ -151,9 +147,12 @@ fit_nullmodel <- function(fixed, data = parent.frame(), kins, use_sparse = NULL, if(use_SPA) { X <- obj_nullmodel$X + muhat <- obj_nullmodel$fitted.values + working <- muhat*(1-muhat) - obj_nullmodel$XW <- as.matrix(crossprod(X,obj_nullmodel$Sigma_i)) - obj_nullmodel$XXWX_inv <- as.matrix(X%*%obj_nullmodel$cov) + ## generate XW + obj_nullmodel$XW <- t(X*working) + obj_nullmodel$XXWX_inv <- X%*%solve(t(X*working)%*%X) } } obj_nullmodel$relatedness <- TRUE diff --git a/README.md b/README.md index b2be529..a3c8105 100644 --- a/README.md +++ b/README.md @@ -31,7 +31,7 @@ Please see the **STAARpipeline** user ma ## Data Availability The whole-genome functional annotation data assembled from a variety of sources and the precomputed annotation principal components are available at the [Functional Annotation of Variant - Online Resource (FAVOR)](https://favor.genohub.org) site and [FAVOR Essential Database](https://doi.org/10.7910/DVN/1VGTJI). ## Version -The current version is 0.9.7.1 (August 9, 2024). +The current version is 0.9.7.1 (October 25, 2024). ## Citation If you use **STAARpipeline** and **STAARpipelineSummary** for your work, please cite: