tests/testthat/test-weighted-population.R

#  File tests/testthat/test-weighted-population.R in package ergm, part of the
#  Statnet suite of packages for network analysis, https://statnet.org .
#
#  This software is distributed under the GPL-3 license.  It is free,
#  open source, and has the attribution requirements (GPL Section 7) at
#  https://statnet.org/attribution .
#
#  Copyright 2003-2023 Statnet Commons
################################################################################

test_that("binary tree WtPop produces appropriate samples from uniform random weights", {
  w <- runif(100L)
  n <- 1000000L
  s <- .Call("test_weighted_population", w, n, 'B') + 1L
  
  r <- tabulate(s, nbins = length(w))
  
  p <- w/sum(w)
  
  e <- n*p
    
  v <- n*p*(1 - p)
  
  d <- (r - e)/sqrt(v)
  
  expect_true(max(abs(d)) < 6)
})

test_that("binary tree WtPop produces appropriate samples from mixed Poisson random weights", {
  w <- sample(as.double(c(rpois(50L, 1), rpois(50L, 10))))
  n <- 1000000L
  s <- .Call("test_weighted_population", w, n, 'B') + 1L
  
  r <- tabulate(s, nbins = length(w))
  
  p <- w/sum(w)
  
  e <- n*p
    
  v <- n*p*(1 - p)
  
  v[w == 0] <- 1/100 # so even one sample will fail the test below
  
  d <- (r - e)/sqrt(v)
  
  expect_true(max(abs(d)) < 6)
})


test_that("Walker WtPop produces appropriate samples from uniform random weights", {
  w <- runif(100L)
  n <- 1000000L
  s <- .Call("test_weighted_population", w, n, 'W') + 1L
  
  r <- tabulate(s, nbins = length(w))
  
  p <- w/sum(w)
  
  e <- n*p
    
  v <- n*p*(1 - p)
  
  d <- (r - e)/sqrt(v)
  
  expect_true(max(abs(d)) < 6)
})

test_that("Walker WtPop produces appropriate samples from mixed Poisson random weights", {
  w <- sample(as.double(c(rpois(50L, 1), rpois(50L, 10))))
  n <- 1000000L
  s <- .Call("test_weighted_population", w, n, 'W') + 1L
  
  r <- tabulate(s, nbins = length(w))
  
  p <- w/sum(w)
  
  e <- n*p
    
  v <- n*p*(1 - p)
  
  v[w == 0] <- 1/100 # so even one sample will fail the test below
  
  d <- (r - e)/sqrt(v)
  
  expect_true(max(abs(d)) < 6)
})

Try the ergm package in your browser

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

ergm documentation built on May 31, 2023, 8:04 p.m.