| Version: | 1.3.3 |
| Date: | 2024-02-11 |
| Title: | A Synchronized Tausworthe RNG for R and Python |
| Author: | Gertjan van den Burg <gertjanvandenburg@gmail.com> |
| Maintainer: | Gertjan van den Burg <gertjanvandenburg@gmail.com> |
| Depends: | R (≥ 3.0.0) |
| Description: | Generate the same random numbers in R and Python. |
| License: | GPL-2 |
| Imports: | methods |
| Suggests: | testthat |
| Encoding: | UTF-8 |
| RoxygenNote: | 7.3.1 |
| NeedsCompilation: | yes |
| Packaged: | 2024-02-11 12:25:36 UTC; gertjan |
| Repository: | CRAN |
| Date/Publication: | 2024-02-11 12:40:02 UTC |
SyncRNG - Synchronized Random Numbers in R and Python
Description
The SyncRNG package provides a random number generator implemented in C and linked to both R and Python. This way, you can generate the same random number sequence in both languages by using the same seed.
The package implements a Tausworthe LSFR RNG (more details at https://gertjanvandenburg.com/blog/syncrng/). This is a very fast pseudo-random number generator.
Usage
There are two ways to use this package in R. It can be used as a reference class, where a SyncRNG object is used to keep the state of the generator and numbers are generated using the object methods. It can also be used as a user-defined random number generator using the strategy outlined in .Random.user. See the examples section below.
Author(s)
Gerrit J.J. van den Burg
Maintainer: Gerrit J.J. van den Burg <gertjanvandenburg@gmail.com>
References
URL: https://github.com/GjjvdBurg/SyncRNG
Examples
library(SyncRNG)
# As user defined RNG:
set.seed(0, 'user', 'user')
runif(2)
# [1] 3.666952e-04 6.257184e-05
set.seed(0, 'user', 'user')
rnorm(2)
# [1] 0.01006027 0.42889422
# As class:
s <- SyncRNG(seed=0)
s$rand()
# [1] 0.0003666952
s$rand()
# [1] 6.257184e-05
A Reference Class for SyncRNG
Description
See syncrng-package for package documentation.
Fields
seedThe seed for the random number generator
stateThe current state of the RNG, should not be modified by the user
Methods
initialize(..., seed = 0)Initialize the RNG using the C function R_syncrng_seed
rand()Generate a single random float in the range [0, 1)
randbelow(n)Generate a random integer below a given number
randi()Generate a single random 32-bit integer
shuffle(x)Randomly shuffle a provided array of values
Examples
s <- SyncRNG(seed=123456)
for (i in 1:10)
cat(s$randi(), '\n')