tests/bake.R

### test of reproducibility utilities

library(pomp)
options(digits=2,pomp_archive_dir=tempdir())

set.seed(5499)
w1 <- runif(2)
w4 <- freeze({runif(5)},seed=c(499586,588686,39995866))
w2 <- runif(2)
w5 <- freeze(runif(5),seed=499586)
set.seed(5499)
w3 <- runif(4)
stopifnot(
  identical(c(w1,w2),w3),
  identical(w4,w5)
)

set.seed(32765883)
x1 <- bake({runif(4)},file="bake1.rds",timing=FALSE)
x2 <- bake({runif(4)},file="bake2.rds",seed=32765883,timing=FALSE)
x3 <- bake({runif(4)},file="bake1.rds",timing=FALSE)
x3a <- bake({  runif(4)},file="bake1.rds",timing=FALSE)
rm(.Random.seed)
x4 <- bake({runif(4)},file="bake3.rds",seed=59566)
x5 <- bake({runif(5)},file="bake1.rds")
x6 <- bake({runif(5)},file="bake1.rds")
x7 <- bake({x1+runif(1)},file="bake4.rds")
x8 <- bake({x1+runif(1)},file="bake4.rds",dependson=x1)
x9 <- bake({x1+runif(1)},file="bake4.rds",dependson=x1)
x10 <- bake({x1+runif(1)},file="bake4.rds",dependson=list(x1,x6))
c <- function(x) x+5
x11 <- bake({x1+runif(1)},file="bake4.rds",dependson=list(x1,c))
try(
  x12 <- bake({x1+runif(1)},file="bake4.rds",dependson=list(c,x1,x13))
)
try(
  x12 <- bake({x1+runif(1)},file="bake4.rds",dependson=list(c,x1,x13,x14))
)
x13 <- bake({x1+runif(1)},seed=233,file="bake4.rds",dependson=x1,info=TRUE)
stopifnot(
  identical(x1,x2),
  identical(x1,x3),
  identical(x3,x3a),
  identical(x5,x6),
  !identical(x3,x5),
  !identical(x7,x8),
  identical(x8,x9),
  !identical(x9,x10),
  !exists("x12"),
  length(attr(x13,"ingredients"))==5,
  attr(x13,"ingredients")$seed==233
)

saveRDS(x1,file=file.path(tempdir(),"tmp.rds"))
try(x1 <- bake({runif(4)},file="tmp.rds"))
saveRDS(x6,file=file.path(tempdir(),"tmp.rds"))
invisible(bake({runif(4)},file="tmp.rds"))

set.seed(113848)
stew({y1 <- runif(4)},file="stew1.rda")
stew({y2 <- runif(4)},file="stew2.rda",seed=113848)
y3 <- y1
print(stew({y1 <- runif(4)},file="stew1.rda"))
rm(.Random.seed)
stew({y4 <- runif(4)},file="stew3.rda",seed=59566)
y5 <- y1+y2 
stew({y6 <- y1+y2},dependson=list(y1,y2),file="stew3.rda")
stopifnot(
  identical(y1,y2),
  identical(y1,y3),
  identical(y5,y6)
)
y1 <- 0
stew({y6 <- y1+y2},dependson=list(y1,y2),file="stew3.rda")
stopifnot(
  identical(y2,y6),
  !exists(".ingredients"),
  exists(".system.time")
)
stew({y6 <- y1+y2},info=TRUE,file="stew3.rda")
stopifnot(
  identical(y2,y6),
  is.list(.ingredients),
  length(.ingredients)==5
)

window(sir2(),end=0.5) -> po
simulate(po,seed=1347484107L) -> x
freeze(simulate(po),seed=1347484107L) -> y
stopifnot(identical(x,y))

stopifnot(
  is.null(freeze({rnorm(5); NULL},seed=3494995)),
  is.list(bake({rnorm(5); NULL},seed=3494995,file="bake4.rds"))
)

rm(.Random.seed)
invisible(bake({runif(4)},file="b99.rds",seed=32765883))
rm(.Random.seed)
print(stew({runif(4)},file="s99.rda",seed=32765883))
rm(.Random.seed)
invisible(freeze({runif(4)},seed=32765883))
invisible(freeze({runif(4)}))

bake({runif(5)},file="tmp1.rds",info=TRUE) -> x
attr(x,"ingredients") <- NULL
saveRDS(x,file=file.path(tempdir(),"tmp1.rds"))
bake({runif(5)},file="tmp1.rds") -> y
bake({runif(5)},file="tmp1.rds") -> y
stopifnot(identical(x,y))

stew({x <- 33; y <- runif(5)},file="tmp1.rda")
xx <- x; yy <- y
save(x,y,file=file.path(tempdir(),"tmp1.rda"))
stew({x <- 33; y <- runif(5)},file="tmp1.rda")
stew({x <- 33; y <- runif(5)},file="tmp1.rda")
stopifnot(
  identical(x,xx),
  identical(y,yy)
)

stew({x <- 33; y <- runif(5)},seed=99,file="tmp2.rda")
xx <- x; yy <- y
save(x,y,file=file.path(tempdir(),"tmp2.rda"))
stew({x <- 33; y <- runif(5)},file="tmp2.rda")
stew({x <- 33; y <- runif(5)},seed=99,file="tmp2.rda")
stopifnot(
  identical(x,xx),
  identical(y,yy)
)

capture.output(
  {
    bake(file="results/bob/mary/tmp.rds",rnorm(5)) -> x1
    bake(file="results/bob/mary/tmp.rds",rnorm(5)) -> x2
    bake(file="mary/tmp.rds",rnorm(5),dir=file.path(tempdir(),"results/bob")) -> x3
    op <- options(pomp_archive_dir=file.path(tempdir(),"results"))
    bake(file="bob/mary/tmp.rds",rnorm(5)) -> x4
    bake(file="results/bob/mary/tmp.rds",rnorm(5)) -> x5
    options(op)
    bake(file="results/results/bob/mary/tmp.rds",rnorm(5)) -> x6
  },
  type="message"
) -> out
stopifnot(
  identical(x1,x2),
  identical(x1,x3),
  identical(x1,x4),
  !identical(x1,x5),
  identical(x5,x6),
  length(out)==2,
  grepl("^NOTE: creating archive directory",out),
  grepl("results/bob/mary'.",out),
  grepl("results/results/bob/mary'.",out[2])
)
kingaa/pomp documentation built on May 4, 2024, 1:20 p.m.