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] 76 05 c8 73 80 f3 91 82 b0 73
Bytes are 8 bit and hence can have 2^8 = 256 possible
values.
[1] 118 5 200 115 128 243 145 130 176 115
Each random byte can be decomposed into 8 random bits (booleans)
[1] FALSE TRUE FALSE FALSE TRUE TRUE TRUE TRUE
rand_num is a simple (2 lines) wrapper to
rand_bytes to generate random numbers (doubles) between 0
and 1.
[1] 0.5437449 0.5717184 0.8217008 0.3518540 0.3539974 0.4943517 0.5203454
[8] 0.4944972 0.5413172 0.8420463
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: