rand/xorshift: simplify result operator specialisations
This commit is contained in:
parent
325a7405b5
commit
f741986c3f
@ -34,31 +34,44 @@ xorshift<T>::xorshift (T seed):
|
|||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
namespace util { namespace rand {
|
// setup the constants a, b, and c. we use the values from the example
|
||||||
template <>
|
// generators provided in Marsaglia's paper.
|
||||||
uint32_t
|
template <typename T>
|
||||||
xorshift<uint32_t>::operator() (void)
|
struct constants;
|
||||||
{
|
|
||||||
m_state ^= m_state << 13u;
|
|
||||||
m_state ^= m_state >> 17u;
|
|
||||||
m_state ^= m_state << 5u;
|
|
||||||
|
|
||||||
return m_state;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
template <>
|
template <>
|
||||||
uint64_t
|
struct constants<uint32_t>
|
||||||
xorshift<uint64_t>::operator() (void)
|
{
|
||||||
{
|
static constexpr uint32_t a = 13u;
|
||||||
m_state ^= m_state << 13u;
|
static constexpr uint32_t b = 17u;
|
||||||
m_state ^= m_state >> 7u;
|
static constexpr uint32_t c = 5u;
|
||||||
m_state ^= m_state << 17u;
|
};
|
||||||
|
|
||||||
return m_state;
|
|
||||||
}
|
//-----------------------------------------------------------------------------
|
||||||
} }
|
template <>
|
||||||
|
struct constants<uint64_t>
|
||||||
|
{
|
||||||
|
static constexpr uint64_t a = 13u;
|
||||||
|
static constexpr uint64_t b = 7u;
|
||||||
|
static constexpr uint64_t c = 17u;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
template <typename T>
|
||||||
|
typename xorshift<T>::result_type
|
||||||
|
xorshift<T>::operator() (void)
|
||||||
|
{
|
||||||
|
m_state ^= m_state >> constants<T>::a;
|
||||||
|
m_state ^= m_state << constants<T>::b;
|
||||||
|
m_state ^= m_state >> constants<T>::c;
|
||||||
|
|
||||||
|
CHECK_NEZ (m_state);
|
||||||
|
return m_state;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
Loading…
Reference in New Issue
Block a user