tests/testthat/test-powerCurve.R

context('SpowerCurve')

expect_class <- function(x, class) expect_true(inherits(x, class))

test_that('SpowerCurve', {

    library(Spower)

	p_t.test(n=NA, d=.2) |>
		SpowerCurve(n=c(30, 90, 270), verbose=FALSE, replications=10, plotly = FALSE) -> out
	expect_class(out, 'gg')

	p_t.test(d=.2) |>
		SpowerCurve(n=c(30, 90, 270), verbose=FALSE, replications=10, plotly = FALSE) -> out
	expect_class(out, 'gg')

	p_t.test(n=NA, d=0.2) |>
	   SpowerCurve(power=c(.2, .4), interval=c(10, 1000), verbose=F, plotly = FALSE) -> out
	expect_class(out, 'gg')

	p_t.test() |>
		SpowerCurve(n=c(30, 90, 270, 550),
				   d=c(.2, .5, .8), replications=10, verbose=F, plotly = FALSE) -> out
	expect_class(out, 'gg')

	p_t.test(n=NA) |>
		SpowerCurve(d=c(.2, .5, .8), power=.80, interval=c(10, 1000), verbose=F, plotly = FALSE) -> out
	expect_class(out, 'gg')

	# p_t.test(n=250) |>
	# 	SpowerCurve(d=c(.2, .5, .6), power=.80, sig.level=NA, verbose=F) -> out
	# expect_class(out, 'gg')

	# multi-output (only first used)
	p_my_t.test <- function(n, d){
		g1 <- rnorm(n)
		g2 <- rnorm(n, mean=d)
		p1 <- t.test(g1, g2, var.equal=FALSE)$p.value
		p2 <- t.test(g1, g2, var.equal=TRUE)$p.value
		c(welch=p1, ind=p2)
	}

	p_my_t.test(n=100, d=.2) |>
		SpowerCurve(n=c(30, 90, 270), verbose=FALSE, replications=10, plotly=FALSE) -> out
	expect_class(out, 'gg')



})

test_that('scope', {

	mygen_fun <- function(n, n2_n1, d, df, ...){
		group1 <- rchisq(n, df=df)
		group1 <-  (group1 - df) / sqrt(2*df)   # Adjusted mean to 0, sd = 1
		group2 <- rnorm(n*n2_n1, mean=d)
		dat <- data.frame(group = factor(rep(c('G1', 'G2'),
											 times = c(n, n*n2_n1))),
						  DV = c(group1, group2))
		dat
	}

	p_my_t.test <- function(n, d, var.equal=FALSE, n2_n1=1, df=10, ...){
		dat <- mygen_fun(n=n, n2_n1=n2_n1, d=d, df=df, ...)
		obj <- t.test(DV ~ group, dat, var.equal=var.equal)
		obj2 <- t.test(DV ~ group, dat, var.equal=TRUE)
		c(obj$p.value, obj2$p.value) # only first used
	}

	# Solve N to get .80 power (a priori power analysis), using defaults
	gg <- p_my_t.test(d = .5) |>
		SpowerCurve(n=c(30, 60, 90), verbose=F, replications=10, plotly=F)
	expect_is(gg, 'gg')

	gg <- p_my_t.test(d = .5) |>
		SpowerCurve(n=c(30, 60, 90), verbose=F, replications=50, plotly=F,
				   parallel=TRUE, ncores=2)
	expect_is(gg, 'gg')


})

Try the Spower package in your browser

Any scripts or data that you put into this service are public.

Spower documentation built on April 4, 2025, 5:11 a.m.