R Under development (unstable) (2023-12-09 r85665 ucrt) -- "Unsuffered Consequences" Copyright (C) 2023 The R Foundation for Statistical Computing Platform: x86_64-w64-mingw32/x64 R is free software and comes with ABSOLUTELY NO WARRANTY. You are welcome to redistribute it under certain conditions. Type 'license()' or 'licence()' for distribution details. R is a collaborative project with many contributors. Type 'contributors()' for more information and 'citation()' on how to cite R or R packages in publications. Type 'demo()' for some demos, 'help()' for on-line help, or 'help.start()' for an HTML browser interface to help. Type 'q()' to quit R. > library("matrixStats") > > for (mode in c("logical", "integer", "double")) { + cat("mode: ", mode, "", sep = "") + n <- 2L + x <- runif(n, min = -5, max = 5) + if (mode == "logical") { + x <- x > 0 + } + storage.mode(x) <- mode + str(x) + + cat("All weights are 1\n") + w <- rep(1, times = n) + m0 <- weighted.mean(x, w) + m1 <- weightedMean(x, w) + str(list(m0 = m0, m1 = m1)) + stopifnot(identical(m1, m0)) + + cat("First weight is 5\n") + # Pull the mean towards zero + w[1] <- 5 + str(w) + m0 <- weighted.mean(x, w) + m1 <- weightedMean(x, w) + str(list(m0 = m0, m1 = m1)) + stopifnot(identical(m1, m0)) + + cat("All weights are 0\n") + # All weights set to zero + w <- rep(0, times = n) + m0 <- weighted.mean(x, w) + m1 <- weightedMean(x, w) + str(list(m0 = m0, m1 = m1)) + stopifnot(identical(m1, m0)) + + cat("First weight is 8.5\n") + # Put even more weight on the zero + w[1] <- 8.5 + m0 <- weighted.mean(x, w) + m1 <- weightedMean(x, w) + str(list(m0 = m0, m1 = m1)) + stopifnot(identical(m1, m0)) + + cat("First weight is Inf\n") + # All weight on the first value + w[1] <- Inf + m0 <- weighted.mean(x, w) + m1 <- weightedMean(x, w) + str(list(m0 = m0, m1 = m1)) + stopifnot(identical(m1, m0)) + + cat("Last weight is Inf\n") + # All weight on the last value + w[1] <- 1 + w[n] <- Inf + m0 <- weighted.mean(x, w) + m1 <- weightedMean(x, w) + str(list(m0 = m0, m1 = m1)) + stopifnot(identical(m1, m0)) + } # for (mode ...) mode: logical logi [1:2] TRUE FALSE All weights are 1 List of 2 $ m0: num 0.5 $ m1: num 0.5 First weight is 5 num [1:2] 5 1 List of 2 $ m0: num 0.833 $ m1: num 0.833 All weights are 0 List of 2 $ m0: num NaN $ m1: num NaN First weight is 8.5 List of 2 $ m0: num 1 $ m1: num 1 First weight is Inf List of 2 $ m0: num NaN $ m1: num NaN Last weight is Inf List of 2 $ m0: num NaN $ m1: num NaN mode: integer int [1:2] -4 -1 All weights are 1 List of 2 $ m0: num -2.5 $ m1: num -2.5 First weight is 5 num [1:2] 5 1 List of 2 $ m0: num -3.5 $ m1: num -3.5 All weights are 0 List of 2 $ m0: num NaN $ m1: num NaN First weight is 8.5 List of 2 $ m0: num -4 $ m1: num -4 First weight is Inf List of 2 $ m0: num NaN $ m1: num NaN Last weight is Inf List of 2 $ m0: num NaN $ m1: num NaN mode: double num [1:2] -1.97 -1.28 All weights are 1 List of 2 $ m0: num -1.62 $ m1: num -1.62 First weight is 5 num [1:2] 5 1 List of 2 $ m0: num -1.86 $ m1: num -1.86 All weights are 0 List of 2 $ m0: num NaN $ m1: num NaN First weight is 8.5 List of 2 $ m0: num -1.97 $ m1: num -1.97 First weight is Inf List of 2 $ m0: num NaN $ m1: num NaN Last weight is Inf List of 2 $ m0: num NaN $ m1: num NaN > > > message("*** Testing for missing values") *** Testing for missing values > # NA tests > xs <- list(A = c(1, 2, 3), B = c(NA, 2, 3), C = c(NA, 2, 3)) > ws <- list(A = c(1, 1, 1), B = c(NA, 1, 1), C = c(1, NA, 1)) > ## NOTE: The (B, B) case with na.rm = TRUE is interesting because > ## even if NAs in 'w' are not dropped by na.rm = TRUE, this one > ## is because 'x' is dropped and therefore that first element > ## is skipped in the computation. It basically does > ## keep <- !is.na(x); x <- x[keep]; w <- w[keep] > ## without looking at 'w'. > for (x in xs) { + for (mode in c("logical", "integer", "double")) { + storage.mode(x) <- mode + for (w in ws) { + for (na.rm in c(FALSE, TRUE)) { + cat(sprintf("mode: %s, na.rm = %s\n", mode, na.rm)) + str(list(x = x, w = w)) + m0 <- weighted.mean(x, w, na.rm = na.rm) + m1 <- weightedMean(x, w, na.rm = na.rm) + str(list(m0 = m0, m1 = m1)) + stopifnot(all.equal(m1, m0)) + } + } + } + } mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] TRUE TRUE TRUE $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] TRUE TRUE TRUE $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] TRUE TRUE TRUE $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] TRUE TRUE TRUE $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] TRUE TRUE TRUE $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] TRUE TRUE TRUE $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] 1 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] 1 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] 1 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] 1 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] 1 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] 1 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = FALSE List of 2 $ x: num [1:3] 1 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: double, na.rm = TRUE List of 2 $ x: num [1:3] 1 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: double, na.rm = FALSE List of 2 $ x: num [1:3] 1 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] 1 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = FALSE List of 2 $ x: num [1:3] 1 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] 1 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 1 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] NA 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = FALSE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: double, na.rm = FALSE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: double, na.rm = FALSE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 1 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] NA 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: logical, na.rm = FALSE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: logical, na.rm = TRUE List of 2 $ x: logi [1:3] NA TRUE TRUE $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: integer, na.rm = FALSE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: integer, na.rm = TRUE List of 2 $ x: int [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = FALSE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: double, na.rm = FALSE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] NA 1 1 List of 2 $ m0: num 1 $ m1: num 1 mode: double, na.rm = FALSE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA mode: double, na.rm = TRUE List of 2 $ x: num [1:3] NA 1 1 $ w: num [1:3] 1 NA 1 List of 2 $ m0: num NA $ m1: num NA > > proc.time() user system elapsed 0.28 0.09 0.37