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] b5 a0 88 aa 0b 54 e2 3e 60 78
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 181 160 136 170 11 84 226 62 96 120
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE FALSE FALSE TRUE FALSE TRUE FALSE FALSE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.58785531 0.22836358 0.35803495 0.13106627 0.63593318 0.06465181
[7] 0.03432692 0.35397316 0.76589290 0.41066198
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: