From 369f39b3efbd53ad4b3579a00debf5671bf5cdcb Mon Sep 17 00:00:00 2001 From: SiWen314 Date: Fri, 9 Aug 2024 13:46:17 -0400 Subject: [PATCH] Replace methods::as with Matrix::Matrix; import Matrix functions individually --- Rpackage/iMRMC/DESCRIPTION | 2 +- Rpackage/iMRMC/NAMESPACE | 4 ++-- Rpackage/iMRMC/R/limitsOfAgreement.R | 11 +++++------ 3 files changed, 8 insertions(+), 9 deletions(-) diff --git a/Rpackage/iMRMC/DESCRIPTION b/Rpackage/iMRMC/DESCRIPTION index dfdc72c0..bc7d8f1b 100644 --- a/Rpackage/iMRMC/DESCRIPTION +++ b/Rpackage/iMRMC/DESCRIPTION @@ -11,5 +11,5 @@ Encoding: UTF-8 LazyData: true Depends: R (>= 3.5.0) RoxygenNote: 7.3.2 -Imports: stats, Matrix, methods +Imports: stats, Matrix Suggests: testthat diff --git a/Rpackage/iMRMC/NAMESPACE b/Rpackage/iMRMC/NAMESPACE index 349cd6a8..86c78fbc 100644 --- a/Rpackage/iMRMC/NAMESPACE +++ b/Rpackage/iMRMC/NAMESPACE @@ -33,10 +33,10 @@ export(successDFtoROCdf) export(uStat11.conditionalD) export(uStat11.jointD) export(undoIMRMCdf) -import(Matrix) import(parallel) import(utils) -importFrom(methods,as) +importFrom(Matrix,Matrix) +importFrom(Matrix,tcrossprod) importFrom(stats,aov) importFrom(stats,model.matrix) importFrom(stats,qnorm) diff --git a/Rpackage/iMRMC/R/limitsOfAgreement.R b/Rpackage/iMRMC/R/limitsOfAgreement.R index 97978e6d..a622b715 100644 --- a/Rpackage/iMRMC/R/limitsOfAgreement.R +++ b/Rpackage/iMRMC/R/limitsOfAgreement.R @@ -97,8 +97,7 @@ #' #' #' @importFrom stats aov var qnorm model.matrix -#' @importFrom methods as -#' @import Matrix +#' @importFrom Matrix Matrix tcrossprod #' @export #' #' @examples @@ -625,7 +624,7 @@ anova3 <- function(df.A, df.B, if.aov = TRUE, type = 1, reader.first = TRUE, ## Compute SS and coefficient for the variance components R.full <- RSS(X,Y,output.q = T,is.sparseQR = is.sparseQR) if(is.sparseQR){ - sparseX <- as(X[,R.full$ind],"sparseMatrix") + sparseX <- Matrix(X[,R.full$ind],sparse = TRUE) }else{ sparseX <- NULL } @@ -702,7 +701,7 @@ anova3 <- function(df.A, df.B, if.aov = TRUE, type = 1, reader.first = TRUE, if(is.sparseQR){ X<-model.matrix(~ readerID + caseID + modalityID + readerID:modalityID + caseID:modalityID, data = df_2Modality) - sparseX<-as(X[,R.no_RC$ind],"sparseMatrix") + sparseX<-Matrix(X[,R.no_RC$ind],sparse=TRUE) } R.RM_C <- RSS(seq(1,nR*nM+nC-1),Y,R.no_RC$q, R.no_RC$ind,is.sparseQR,sparseX, Xrc = X_rc, Xcm = X_cm) @@ -768,7 +767,7 @@ RSS <- function(X, Y, q=NULL,ind=NULL, is.sparseQR=F, sparseX=NULL, ind <- decom$pivot[1:k] if(is.sparseQR){ - decom2<- qr(as(X[,ind],"sparseMatrix")) + decom2<- qr(Matrix(X[,ind],sparse=TRUE)) q <- qr.Q(decom2) }else{ q <- qr.Q(decom)[,1:k] @@ -801,7 +800,7 @@ RSS <- function(X, Y, q=NULL,ind=NULL, is.sparseQR=F, sparseX=NULL, X_res <- list(Xr, Xc, Xrc, Xrm, Xcm) - coef_var <- unlist(lapply(X_res, function(X) if(!is.null(X)) sum(diag(M %*% tcrossprod(as(X,"sparseMatrix")))) else 0)) + coef_var <- unlist(lapply(X_res, function(X) if(!is.null(X)) sum(diag(as.matrix(M %*% tcrossprod(Matrix(X,sparse=TRUE))))) else 0)) if((!output.q) | is.sparseQR){ q=NULL }