The rand_bytes
function binds to RAND_bytes in
OpenSSL to generate cryptographically strong pseudo-random bytes. See
the OpenSSL documentation for what this means.
[1] 8e b6 7c a2 b6 e4 e3 dd 15 91
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 142 182 124 162 182 228 227 221 21 145
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE TRUE FALSE FALSE TRUE TRUE FALSE TRUE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.43350700 0.26486244 0.09633253 0.71699619 0.31865128 0.07485673
[7] 0.27053903 0.64795922 0.77003087 0.11141701
To map random draws from [0,1] into a probability density, we can use
a Cumulative
Distribution Function. For example we can combine qnorm
and rand_num
to simulate rnorm
:
Same for discrete distributions: