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] a5 e3 33 73 27 a3 73 07 71 c8
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 165 227 51 115 39 163 115 7 113 200
Each random byte can be decomposed into 8 random bits (booleans)
[1] FALSE TRUE FALSE FALSE TRUE TRUE TRUE FALSE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.62463095 0.06743850 0.96509058 0.76047650 0.46218859 0.06685063
[7] 0.43044433 0.59437160 0.86275382 0.61499372
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: