rbinom_trng: Binomial random numbers via TRNG.

View source: R/rbinom_trng.R

rbinom_trngR Documentation

Binomial random numbers via TRNG.

Description

Random number generation for the binomial distribution using the TRNG C++ library.

Usage

rbinom_trng(n, size, prob, engine = NULL, parallelGrain = 0L)

Arguments

n

Number of observations.

size, prob

Parameters of the distribution, with the same meaning as in rbinom. Note however that only scalar values are accepted.

engine

Optional TRNG engine object; if missing or NULL, the current engine controlled via TRNG.Random is used.

parallelGrain

Optional argument controlling the parallel simulation of random variates (see ‘Parallel Simulation’ below for details).

Value

Numeric vector of random variates generated with the given parameters. The length is determined by n.

Parallel Simulation

When a positive value of argument parallelGrain is supplied, random variates are simulated in parallel, provided a parallel random number engine is selected. This is done using RcppParallel via parallelFor, which uses the supplied parallelGrain to control the grain size (the number of threads being controlled by setThreadOptions). The grain size can greatly affect the overhead of performing the required block splitting jump operations and should be selected carefully. Note that TRNG guarantees the outcome of such parallel execution to be equivalent to a purely sequential simulation.

See Also

rbinom, TRNG.Engine, TRNG.Random.

Other TRNG distributions: rlnorm_trng(), rnorm_trng(), rpois_trng(), runif_trng()

Examples

## generate 10 random variates using the current TRNG engine
rbinom_trng(10, size = 1L, prob = 0.5)

## use a TRNG engine reference class object
r <- yarn2$new()
rbinom_trng(10, size = 1L, prob = 0.5, engine = r)

## generate 100k random variates in parallel, with 2 threads and 100 grain size
TRNGseed(117)
RcppParallel::setThreadOptions(numThreads = 2L)
x_parallel <- rbinom_trng(100e3, size = 1L, prob = 0.5, parallelGrain = 100L)
TRNGseed(117)
x_serial <- rbinom_trng(100e3, size = 1L, prob = 0.5)
identical(x_serial, x_parallel)

rTRNG documentation built on March 18, 2022, 7:15 p.m.