rand/lcg: add min/max/discard operations
This commit is contained in:
parent
62482594bd
commit
325a7405b5
28
rand/lcg.cpp
28
rand/lcg.cpp
@ -56,6 +56,34 @@ lcg<T,M,A,C>::operator() (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
template <typename T, T M, T A, T C>
|
||||||
|
typename lcg<T,M,A,C>::result_type
|
||||||
|
lcg<T,M,A,C>::min (void)
|
||||||
|
{
|
||||||
|
return std::numeric_limits<result_type>::min ();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
template <typename T, T M, T A, T C>
|
||||||
|
typename lcg<T,M,A,C>::result_type
|
||||||
|
lcg<T,M,A,C>::max (void)
|
||||||
|
{
|
||||||
|
return std::numeric_limits<result_type>::max ();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
template <typename T, T M, T A, T C>
|
||||||
|
void
|
||||||
|
lcg<T,M,A,C>::discard (unsigned count)
|
||||||
|
{
|
||||||
|
while (count--)
|
||||||
|
(*this)();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
template struct util::rand::lcg<uint32_t, util::pow2(31), 1103515245, 12345>;
|
template struct util::rand::lcg<uint32_t, util::pow2(31), 1103515245, 12345>;
|
||||||
template struct util::rand::lcg<uint64_t, 0ul, 6364136223846793005ul, 1ul>;
|
template struct util::rand::lcg<uint64_t, 0ul, 6364136223846793005ul, 1ul>;
|
||||||
|
@ -30,11 +30,18 @@ namespace util { namespace rand {
|
|||||||
template <typename T, T M, T A, T C>
|
template <typename T, T M, T A, T C>
|
||||||
struct lcg {
|
struct lcg {
|
||||||
public:
|
public:
|
||||||
|
using result_type = T;
|
||||||
|
|
||||||
static_assert (std::is_unsigned<T>::value,
|
static_assert (std::is_unsigned<T>::value,
|
||||||
"LCG generates integer overflow which is undefined behaviour for signed types");
|
"LCG generates integer overflow which is undefined behaviour for signed types");
|
||||||
lcg (T seed);
|
lcg (T seed);
|
||||||
|
|
||||||
T operator() (void);
|
result_type operator() (void);
|
||||||
|
|
||||||
|
static result_type min (void);
|
||||||
|
static result_type max (void);
|
||||||
|
|
||||||
|
void discard (unsigned);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
T m_x;
|
T m_x;
|
||||||
|
Loading…
Reference in New Issue
Block a user