1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- #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
|