54 static void initRand(std::mt19937* which = 0,
const bool random =
false,
const int seed = 23423);
60 static inline double rand(std::mt19937* rng = 0) {
64 const double res = double((*rng)() / 4294967296.0);
65 #ifdef DEBUG_RANDCALLS 68 std::cout <<
"DEBUG\n";
70 std::cout <<
" rand call=" <<
myCallCount <<
" val=" << res <<
"\n";
76 static inline double rand(
double maxV, std::mt19937* rng = 0) {
77 return maxV *
rand(rng);
81 static inline double rand(
double minV,
double maxV, std::mt19937* rng = 0) {
82 return minV + (maxV - minV) *
rand(rng);
86 static inline int rand(
int maxV, std::mt19937* rng = 0) {
90 unsigned int usedBits = maxV - 1;
91 usedBits |= usedBits >> 1;
92 usedBits |= usedBits >> 2;
93 usedBits |= usedBits >> 4;
94 usedBits |= usedBits >> 8;
95 usedBits |= usedBits >> 16;
100 result = (*rng)() & usedBits;
101 }
while (result >= maxV);
106 static inline int rand(
int minV,
int maxV, std::mt19937* rng = 0) {
107 return minV +
rand(maxV - minV, rng);
111 static inline long long int rand(
long long int maxV, std::mt19937* rng = 0) {
112 if (maxV <= std::numeric_limits<int>::max()) {
113 return rand((
int)maxV, rng);
118 unsigned long long int usedBits = maxV - 1;
119 usedBits |= usedBits >> 1;
120 usedBits |= usedBits >> 2;
121 usedBits |= usedBits >> 4;
122 usedBits |= usedBits >> 8;
123 usedBits |= usedBits >> 16;
124 usedBits |= usedBits >> 32;
127 long long int result;
129 result = (((
unsigned long long int)(*rng)() << 32) | (*rng)()) & usedBits;
130 }
while (result >= maxV);
135 static inline long long int rand(
long long int minV,
long long int maxV, std::mt19937* rng = 0) {
136 return minV +
rand(maxV - minV, rng);
140 static inline double randNorm(
double mean,
double variance, std::mt19937* rng = 0) {
144 u =
rand(2.0, rng) - 1;
145 const double v =
rand(2.0, rng) - 1;
147 }
while (q == 0.0 || q >= 1.0);
148 return (
double)(mean + variance * u * sqrt(-2 * log(q) / q));
153 static inline const T&
155 assert(v.size() > 0);
156 return v[
rand((
int)v.size(), rng)];
164 std::ostringstream oss;
170 static void loadState(
const std::string& state, std::mt19937* rng = 0) {
174 std::istringstream iss(state);
static std::string saveState(std::mt19937 *rng=0)
save rng state to string
static double rand(double minV, double maxV, std::mt19937 *rng=0)
Returns a random real number in [minV, maxV)
static void insertRandOptions()
Initialises the given options container with random number options.
static double rand(double maxV, std::mt19937 *rng=0)
Returns a random real number in [0, maxV)
static double rand(std::mt19937 *rng=0)
Returns a random real number in [0, 1)
static int rand(int minV, int maxV, std::mt19937 *rng=0)
Returns a random integer in [minV, maxV-1].
static int myCallCount
only used for debugging;
static long long int rand(long long int maxV, std::mt19937 *rng=0)
Returns a random 64 bit integer in [0, maxV-1].
Utility functions for using a global, resetable random number generator.
static int rand(int maxV, std::mt19937 *rng=0)
Returns a random integer in [0, maxV-1].
static double randNorm(double mean, double variance, std::mt19937 *rng=0)
Access to a random number from a normal distribution.
static long long int rand(long long int minV, long long int maxV, std::mt19937 *rng=0)
Returns a random 64 bit integer in [minV, maxV-1].
static std::mt19937 myRandomNumberGenerator
the random number generator to use
static void initRand(std::mt19937 *which=0, const bool random=false, const int seed=23423)
Initialises the random number generator with hardware randomness or seed.
static const T & getRandomFrom(const std::vector< T > &v, std::mt19937 *rng=0)
Returns a random element from the given vector.
A storage for options typed value containers)
static void initRandGlobal(std::mt19937 *which=0)
Reads the given random number options and initialises the random number generator in accordance...
static void loadState(const std::string &state, std::mt19937 *rng=0)
load rng state from string