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] cf c6 d4 de 4b d2 57 82 aa 72
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 207 198 212 222 75 210 87 130 170 114
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE FALSE FALSE TRUE FALSE 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.66596172 0.09169210 0.64679186 0.99047161 0.09681197 0.28234803
[7] 0.44314562 0.20144093 0.01691700 0.99815953
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: