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] bd 23 b5 30 99 0f 08 ae f7 c7
Bytes are 8 bit and hence can have 2^8 = 256 possible
values.
[1] 189 35 181 48 153 15 8 174 247 199
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE FALSE FALSE TRUE FALSE 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.4011525 0.5088206 0.5807913 0.9908808 0.6470002 0.0168557 0.8391489
[8] 0.7326765 0.1946945 0.3133902
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: