tests/testthat/test-stouffer.R

# This tests the Stouffer-related functions.
# library(metapod); library(testthat); source("setup.R"); source("test-stouffer.R")

set.seed(20000)
p1 <- runif(1000)
p2 <- runif(1000)
p3 <- runif(1000)    

REF <- function(..., weights=NULL) {
    Q <- qnorm(rbind(...))
    if (is.null(weights)) weights <- rep(1, nrow(Q))
    Q <- colSums(Q * weights)/sqrt(sum(weights^2))
    pnorm(Q)
}

test_that("parallelStouffer works correctly", {
    pout <- parallelStouffer(list(p1, p2, p3))
    expect_equal(pout$p.value, REF(p1, p2, p3)) 
    expect_equal(pout$representative, max.col(-cbind(p1, p2, p3)))
    expect_true(all(vapply(pout$influential, all, TRUE)))

    parallelTester(p1, p2, p3, FUN=parallelStouffer)

    # Handles ties correctly.
    pout <- parallelStouffer(list(p1, p2, p1))
    expect_equal(pout$p.value, REF(p1, p2, p1))

    pout <- parallelStouffer(list(p1, p1, p1))
    expect_equal(pout$p.value, REF(p1, p1, p1))

    # Works correctly with weights.
    pout <- parallelStouffer(list(p1, p2, p3), c(3,1,2))
    expect_equal(pout$p.value, REF(p1, p2, p3, weights=c(3,1,2)))
    parallelTesterWithWeights(p1, p2, p3, FUN=parallelStouffer)

    # Behaves sensibly at edge cases.
    expect_equal(parallelStouffer(list(0, 0))$p.value, 0)
    expect_equal(parallelStouffer(list(0, 1))$p.value, 0.5)
    expect_equal(parallelStouffer(list(1, 1))$p.value, 1)
})

test_that("parallelStouffer cancels out the zeros and one's", {
    expect_equal(parallelStouffer(list(0, 0, 1))$p.value, 0)
    expect_equal(parallelStouffer(list(0, 1, 1))$p.value, 1)
    expect_equal(parallelStouffer(list(0, 0.5, 1))$p.value, 0.5)

    # Works in log.p=TRUE.
    expect_equal(parallelStouffer(list(-Inf, -Inf, 0), log.p=TRUE)$p.value, -Inf)
    expect_equal(parallelStouffer(list(-Inf, 0, 0), log.p=TRUE)$p.value, 0)
    expect_equal(parallelStouffer(list(-Inf, log(0.5), 0), log.p=TRUE)$p.value, log(0.5))
})

test_that("groupedStouffer works correctly", {
    g <- sample(100, length(p1), replace=TRUE)
    groupedTester(p1, g, pFUN=parallelStouffer, gFUN=groupedStouffer)
    groupedTesterWithWeights(p1, g,  pFUN=parallelStouffer, gFUN=groupedStouffer)
})
LTLA/metapod documentation built on Jan. 19, 2024, 11:49 p.m.