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] e3 43 6b 18 43 11 7c 62 71 a7
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 227 67 107 24 67 17 124 98 113 167
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE TRUE FALSE TRUE TRUE FALSE TRUE FALSE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.5713111 0.8686758 0.8924500 0.2210599 0.5162969 0.5111080 0.3335092
[8] 0.8802155 0.1759816 0.4355922
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: