我正在使用 testthat
为我的 R 包编写测试。我的一项测试使用了 jitter
.我想确保测试是可重复的。
我放set.seed(1014)
library(testthat)
之前或之后在 ./tests/testthat.R
;或 context("Test
中的每个测试文件的顶部(在 ./tests/testthat/test-function.R
之前或之后) ;或 test_that("Example works"){jitter(1)}))
中的 ./tests/testthat/test-function.R
内?为什么?
最佳答案
如果你只声明set.seed()
一次,那么您总是需要以相同的顺序运行使用随机性的测试以获得相同的结果。但是,单元测试仅在以特定顺序运行时才起作用可能不是一个好主意。您应该将种子设置为接近您需要验证返回随机值的时间。
这是一个可以为代码块设置种子的函数
with_seed <- function(seed, code) {
code <- substitute(code)
orig.seed <- .Random.seed
on.exit(.Random.seed <<- orig.seed)
set.seed(seed)
eval.parent(code)
}
你可以像这样运行它
with_seed(5, rnorm(5))
或者
with_seed(5, {
a <- rnorm(5)
b <- runif(5)
a + b
})
但是你仍然会得到 block 外原始种子的随机数。
如果您希望从现有包中提取这样的功能,withr::set_seed似乎做同样的事情。
关于r - 我在哪里为 R 包中的测试指定随机种子?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56191862/