[Rd] package load altering RNG state
    Martin Maechler 
    maechler at stat.math.ethz.ch
       
    Tue Feb  7 15:59:58 CET 2017
    
    
  
>>>>> Henric Winell <nilsson.henric at gmail.com>
>>>>>     on Tue, 7 Feb 2017 13:37:42 +0100 writes:
    > Hi, On 2017-02-07 13:12, Benjamin Tyner wrote:
    >> Hello
    >> 
    >> When loading a package, I'm wondering if it's frowned
    >> upon for the package to alter the state of the random
    >> number generator? I guess not, since the parallel package
    >> does it?
    > Surprisingly it is not frowned upon, but it *is* a
    > nuisance.  I brought it up a couple of years ago
    > http://r.789695.n4.nabble.com/parallel-package-changes-Random-seed-td4686321.html
    > along with a patch, but was told off...
    >> 
    >> > set.seed(6860) > old.seed <- .GlobalEnv$.Random.seed >
    >> library(parallel) > new.seed <- .GlobalEnv$.Random.seed >
    >> identical(old.seed, new.seed) [1] FALSE
    >> 
    >> I ask because, I found myself writing a custom wrapper
    >> around library() to restore the original RNG state, in
    >> order to increase reproducibility.  But now wondering if
    >> others would welcome such a feature to be added to base
    >> R? Either something very general like
    >> 
    >> preserveRNGstate(library(parallel))
    >> 
    >> or perhaps an specific enhancement to library itself?
    > I would very much welcome a change, but in the light of
    > things it doesn't seem likely.
    > Henric Winell
Sometimes things change ... and not always for the worse.  I've
found a version of your original patch idea which is very
efficient nice (in my eyes) and still leaves
	system.time(loadNamespace("parallel"))
to round to 0, i.e. needing less than 1 ms.
   --> in R-devel svn rev 72136
Martin
    
    
More information about the R-devel
mailing list