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] d7 b4 76 80 d8 08 ff 82 04 d5
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 215 180 118 128 216 8 255 130 4 213
Each random byte can be decomposed into 8 random bits (booleans)
[1] FALSE TRUE FALSE FALSE FALSE FALSE TRUE TRUE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.84379695 0.85122923 0.07992362 0.62471906 0.14912057 0.42585147
[7] 0.42479059 0.47446255 0.56221136 0.24065380
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: