1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Do not modify this file since it was automatically generated from:
%
% withSeed.R
%
% by the Rdoc compiler part of the R.oo package.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\name{withSeed}
\alias{withSeed}
\title{Evaluate an R expression with a temporarily set random set}
\description{
Evaluate an R expression with a temporarily set random set.
}
\usage{
withSeed(expr, seed, ..., substitute=TRUE, envir=parent.frame())
}
\arguments{
\item{expr}{The R expression to be evaluated.}
\item{seed, ...}{Arguments passed to \code{\link[base]{set.seed}}().}
\item{substitute}{If \code{\link[base:logical]{TRUE}}, argument \code{expr} is
\code{\link[base]{substitute}()}:ed, otherwise not.}
\item{envir}{The \code{\link[base]{environment}} in which the expression should be evaluated.}
}
\value{
Returns the results of the expression evaluated.
}
\details{
Upon exit (also on errors), this function will restore
\code{\link[base]{.Random.seed}} in the global environment to the value
it had upon entry. If it did not exist, it will be removed.
}
\author{Henrik Bengtsson}
\examples{
# Generate a random number
y0 <- runif(1)
print(y0)
# Generate a random number using the same seed over and over
yp <- NULL
for (ii in 1:10) {
y <- withSeed({
runif(1)
}, seed=0x42)
print(y)
# Assert identical
if (!is.null(yp)) stopifnot(identical(y, yp))
yp <- y
}
# Generate a random number
y <- runif(1)
print(y)
}
\seealso{
Internally, \code{\link[base]{set.seed}}() is used to set the random seed.
}
\keyword{IO}
\keyword{programming}
|