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] 87 0c a7 29 ae ea bd 82 90 7a
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 135 12 167 41 174 234 189 130 144 122
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE FALSE FALSE TRUE FALSE FALSE TRUE TRUE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.3023623 0.3385951 0.8058590 0.5396589 0.3526036 0.8267324 0.3740027
[8] 0.5152415 0.4222201 0.1089025
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: