59 lines
1.0 KiB
C++
59 lines
1.0 KiB
C++
|
#ifndef BOOST_UTILITY_DETAIL_MINSTD_RAND_HPP_INCLUDED
|
||
|
#define BOOST_UTILITY_DETAIL_MINSTD_RAND_HPP_INCLUDED
|
||
|
|
||
|
// Copyright 2017 Peter Dimov
|
||
|
//
|
||
|
// Distributed under the Boost Software License, Version 1.0.
|
||
|
//
|
||
|
// See accompanying file LICENSE_1_0.txt or copy at
|
||
|
// http://www.boost.org/LICENSE_1_0.txt
|
||
|
//
|
||
|
// An implementation of minstd_rand that does not require
|
||
|
// the Random library
|
||
|
|
||
|
#include <boost/cstdint.hpp>
|
||
|
|
||
|
namespace boost
|
||
|
{
|
||
|
namespace detail
|
||
|
{
|
||
|
|
||
|
class minstd_rand
|
||
|
{
|
||
|
private:
|
||
|
|
||
|
boost::uint_least32_t x_;
|
||
|
|
||
|
enum { a = 48271, m = 2147483647 };
|
||
|
|
||
|
public:
|
||
|
|
||
|
minstd_rand(): x_( 1 )
|
||
|
{
|
||
|
}
|
||
|
|
||
|
explicit minstd_rand( boost::uint_least32_t x ): x_( x % m )
|
||
|
{
|
||
|
if( x_ == 0 )
|
||
|
{
|
||
|
x_ = 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
boost::uint_least32_t operator()()
|
||
|
{
|
||
|
boost::uint_least64_t y = x_;
|
||
|
|
||
|
y = ( a * y ) % m;
|
||
|
|
||
|
x_ = static_cast<boost::uint_least32_t>( y );
|
||
|
|
||
|
return x_;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
} // namespace detail
|
||
|
} // namespace boost
|
||
|
|
||
|
#endif // #ifndef BOOST_UTILITY_DETAIL_MINSTD_RAND_HPP_INCLUDED
|