There's effectively a one-way relationship between the seed used in set.seed()
and the information in .Random.seed
; as ?Random.seed
says and @MattTenenbaum's answer shows, the information in .Random.seed
can be saved and restored. I appreciate the desire for a function that would derive a simple integer seed from the current state of .Random.seed
, but in its absence, you have to save and restore the full information ... for example
set.seed(1001)
save(".Random.seed",file="random_state_seed1001.RData") ## save current state
runif(1)
## [1] 0.9856888
runif(1)
## [1] 0.4126285
runif(1)
## [1] 0.4295392
load("random_state_seed1001.RData") ## restore state just after set.seed()
runif(1)
## [1] 0.9856888
As @JoshuaUlrich points out, this only works/is only safe if you don't modify the type of RNG (and type of normal deviate generator) between saving and restoring ...
A more complete solution:
save_rng <- function(savefile=tempfile()) {
if (exists(".Random.seed")) {
oldseed <- get(".Random.seed", .GlobalEnv)
} else stop("don't know how to save before set.seed() or r*** call")
oldRNGkind <- RNGkind()
save("oldseed","oldRNGkind",file=savefile)
invisible(savefile)
}
restore_rng <- function(savefile) {
load(savefile)
do.call("RNGkind",as.list(oldRNGkind)) ## must be first!
assign(".Random.seed", oldseed, .GlobalEnv)
}
Try it out:
set.seed(101)
RNGstore <- save_rng() ## save file name
runif(1)
## [1] 0.3721984
runif(10)
## [1] 0.04382482 0.70968402 0.65769040 0.24985572 0.30005483 0.58486663
## [7] 0.33346714 0.62201196 0.54582855 0.87979573
restore_rng(RNGstore)
runif(1)
## [1] 0.3721984
See also: http://www.cookbook-r.com/Numbers/Saving_the_state_of_the_random_number_generator/