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] ed 00 87 93 a7 39 1b a9 33 2f
Bytes are 8 bit and hence can have 2^8 = 256
possible
values.
[1] 237 0 135 147 167 57 27 169 51 47
Each random byte can be decomposed into 8 random bits (booleans)
[1] TRUE FALSE FALSE TRUE TRUE FALSE FALSE FALSE
rand_num
is a simple (2 lines) wrapper to
rand_bytes
to generate random numbers (doubles) between 0
and 1.
[1] 0.7944142 0.7373317 0.2820268 0.2847352 0.4719795 0.1490563 0.9135691
[8] 0.6522257 0.3659559 0.8181964
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: