annotate DEPENDENCIES/generic/include/boost/random/ranlux.hpp @ 125:34e428693f5d vext

Vext -> Repoint
author Chris Cannam
date Thu, 14 Jun 2018 11:15:39 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 /* boost random/ranlux.hpp header file
Chris@16 2 *
Chris@16 3 * Copyright Jens Maurer 2002
Chris@16 4 * Distributed under the Boost Software License, Version 1.0. (See
Chris@16 5 * accompanying file LICENSE_1_0.txt or copy at
Chris@16 6 * http://www.boost.org/LICENSE_1_0.txt)
Chris@16 7 *
Chris@16 8 * See http://www.boost.org for most recent version including documentation.
Chris@16 9 *
Chris@101 10 * $Id$
Chris@16 11 *
Chris@16 12 * Revision history
Chris@16 13 * 2001-02-18 created
Chris@16 14 */
Chris@16 15
Chris@16 16 #ifndef BOOST_RANDOM_RANLUX_HPP
Chris@16 17 #define BOOST_RANDOM_RANLUX_HPP
Chris@16 18
Chris@16 19 #include <boost/config.hpp>
Chris@16 20 #include <boost/random/subtract_with_carry.hpp>
Chris@16 21 #include <boost/random/discard_block.hpp>
Chris@16 22
Chris@16 23 namespace boost {
Chris@16 24
Chris@16 25 namespace random {
Chris@16 26
Chris@16 27 namespace detail {
Chris@16 28 /**
Chris@16 29 * The ranlux family of generators are described in
Chris@16 30 *
Chris@16 31 * @blockquote
Chris@16 32 * "A portable high-quality random number generator for lattice field theory
Chris@16 33 * calculations", M. Luescher, Computer Physics Communications, 79 (1994)
Chris@16 34 * pp 100-110.
Chris@16 35 * @endblockquote
Chris@16 36 *
Chris@16 37 * The levels are given in
Chris@16 38 *
Chris@16 39 * @blockquote
Chris@101 40 * "RANLUX: A Fortran implementation of the high-quality
Chris@16 41 * pseudorandom number generator of Luescher", F. James,
Chris@16 42 * Computer Physics Communications 79 (1994) 111-114
Chris@16 43 * @endblockquote
Chris@16 44 */
Chris@16 45 class ranlux_documentation {};
Chris@16 46 }
Chris@16 47
Chris@16 48 typedef subtract_with_carry_engine<uint32_t, 24, 10, 24> ranlux_base;
Chris@16 49 typedef subtract_with_carry_01_engine<float, 24, 10, 24> ranlux_base_01;
Chris@16 50 typedef subtract_with_carry_01_engine<double, 48, 10, 24> ranlux64_base_01;
Chris@16 51
Chris@16 52
Chris@16 53 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 54 typedef discard_block_engine<ranlux_base, 223, 24> ranlux3;
Chris@16 55 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 56 typedef discard_block_engine<ranlux_base, 389, 24> ranlux4;
Chris@16 57
Chris@16 58 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 59 typedef discard_block_engine<ranlux_base_01, 223, 24> ranlux3_01;
Chris@16 60 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 61 typedef discard_block_engine<ranlux_base_01, 389, 24> ranlux4_01;
Chris@16 62
Chris@16 63 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 64 typedef discard_block_engine<ranlux64_base_01, 223, 24> ranlux64_3_01;
Chris@16 65 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 66 typedef discard_block_engine<ranlux64_base_01, 389, 24> ranlux64_4_01;
Chris@16 67
Chris@16 68 #if !defined(BOOST_NO_INT64_T) && !defined(BOOST_NO_INTEGRAL_INT64_T)
Chris@16 69 typedef subtract_with_carry_engine<uint64_t, 48, 10, 24> ranlux64_base;
Chris@16 70 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 71 typedef discard_block_engine<ranlux64_base, 223, 24> ranlux64_3;
Chris@16 72 /** @copydoc boost::random::detail::ranlux_documentation */
Chris@16 73 typedef discard_block_engine<ranlux64_base, 389, 24> ranlux64_4;
Chris@16 74 #endif /* !BOOST_NO_INT64_T && !BOOST_NO_INTEGRAL_INT64_T */
Chris@16 75
Chris@16 76
Chris@16 77 typedef subtract_with_carry_engine<uint32_t, 24, 10, 24> ranlux24_base;
Chris@16 78 typedef subtract_with_carry_engine<uint64_t, 48, 5, 12> ranlux48_base;
Chris@16 79
Chris@16 80 typedef discard_block_engine<ranlux24_base, 223, 23> ranlux24;
Chris@16 81 #if !defined(BOOST_NO_INT64_T) && !defined(BOOST_NO_INTEGRAL_INT64_T)
Chris@16 82 typedef discard_block_engine<ranlux48_base, 389, 11> ranlux48;
Chris@16 83 #endif
Chris@16 84 }
Chris@16 85
Chris@16 86 using random::ranlux3;
Chris@16 87 using random::ranlux4;
Chris@16 88 using random::ranlux3_01;
Chris@16 89 using random::ranlux4_01;
Chris@16 90 using random::ranlux64_3_01;
Chris@16 91 using random::ranlux64_4_01;
Chris@16 92 #if !defined(BOOST_NO_INT64_T) && !defined(BOOST_NO_INTEGRAL_INT64_T)
Chris@16 93 using random::ranlux64_3;
Chris@16 94 using random::ranlux64_4;
Chris@16 95 #endif
Chris@16 96
Chris@16 97 } // namespace boost
Chris@16 98
Chris@16 99 #endif // BOOST_RANDOM_LINEAR_CONGRUENTIAL_HPP