67 #include <visp3/core/vpConfig.h>
69 #if defined(_MSC_VER) && (_MSC_VER < 1700)
70 typedef unsigned __int64 uint64_t;
71 typedef unsigned __int32 uint32_t;
76 #if (VISP_CXX_STANDARD > VISP_CXX_STANDARD_11)
128 vpUniRand(uint64_t seed, uint64_t seq = 0x123465789ULL);
133 int uniform(
int a,
int b);
134 float uniform(
float a,
float b);
135 double uniform(
double a,
double b);
136 void setSeed(uint64_t initstate, uint64_t initseq);
146 inline static std::vector<T>
shuffleVector(
const std::vector<T> &inputVector)
148 std::vector<T> shuffled = inputVector;
149 #if (VISP_CXX_STANDARD <= VISP_CXX_STANDARD_11)
150 std::random_shuffle(shuffled.begin(), shuffled.end());
152 std::shuffle(shuffled.begin(), shuffled.end(), std::mt19937 { std::random_device{}() });
158 struct vpPcgStateSetSeq64t
164 vpPcgStateSetSeq64t(uint64_t state_ = 0x853c49e6748fea9bULL, uint64_t inc_ = 0xda3e39cb94b95bdbULL)
165 : state(state_), inc(inc_)
168 typedef struct vpPcgStateSetSeq64t pcg32_random_t;
171 uint32_t boundedRand(uint32_t bound);
175 pcg32_random_t m_rng;
Class for generating random numbers with uniform probability density.
static std::vector< T > shuffleVector(const std::vector< T > &inputVector)
Create a new vector that is a shuffled version of the inputVector.