15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier
95a83710eSEric Fiselier // <random>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // template<class UIntType, size_t w, size_t s, size_t r>
125a83710eSEric Fiselier // class subtract_with_carry_engine
135a83710eSEric Fiselier // {
145a83710eSEric Fiselier // public:
155a83710eSEric Fiselier // // types
165a83710eSEric Fiselier // typedef UIntType result_type;
175a83710eSEric Fiselier //
185a83710eSEric Fiselier // // engine characteristics
195a83710eSEric Fiselier // static constexpr size_t word_size = w;
205a83710eSEric Fiselier // static constexpr size_t short_lag = s;
215a83710eSEric Fiselier // static constexpr size_t long_lag = r;
225a83710eSEric Fiselier // static constexpr result_type min() { return 0; }
235a83710eSEric Fiselier // static constexpr result_type max() { return m-1; }
245a83710eSEric Fiselier // static constexpr result_type default_seed = 19780503u;
255a83710eSEric Fiselier
265a83710eSEric Fiselier #include <random>
275a83710eSEric Fiselier #include <type_traits>
285a83710eSEric Fiselier #include <cassert>
295a83710eSEric Fiselier
3069154d6eSEric Fiselier #include "test_macros.h"
3169154d6eSEric Fiselier
32aae63566SStephan T. Lavavej template <class T>
where(const T &)33aae63566SStephan T. Lavavej void where(const T &) {}
345a83710eSEric Fiselier
355a83710eSEric Fiselier void
test1()365a83710eSEric Fiselier test1()
375a83710eSEric Fiselier {
385a83710eSEric Fiselier typedef std::ranlux24_base E;
395a83710eSEric Fiselier static_assert((E::word_size == 24), "");
405a83710eSEric Fiselier static_assert((E::short_lag == 10), "");
415a83710eSEric Fiselier static_assert((E::long_lag == 24), "");
42ae3c4eecSStephan T. Lavavej #if TEST_STD_VER >= 11
43ae3c4eecSStephan T. Lavavej static_assert((E::min() == 0), "");
44ae3c4eecSStephan T. Lavavej static_assert((E::max() == 0xFFFFFF), "");
45ae3c4eecSStephan T. Lavavej #else
46ae3c4eecSStephan T. Lavavej assert((E::min() == 0));
47ae3c4eecSStephan T. Lavavej assert((E::max() == 0xFFFFFF));
48ae3c4eecSStephan T. Lavavej #endif
495a83710eSEric Fiselier static_assert((E::default_seed == 19780503u), "");
505a83710eSEric Fiselier where(E::word_size);
515a83710eSEric Fiselier where(E::short_lag);
525a83710eSEric Fiselier where(E::long_lag);
535a83710eSEric Fiselier where(E::default_seed);
545a83710eSEric Fiselier }
555a83710eSEric Fiselier
565a83710eSEric Fiselier void
test2()575a83710eSEric Fiselier test2()
585a83710eSEric Fiselier {
595a83710eSEric Fiselier typedef std::ranlux48_base E;
605a83710eSEric Fiselier static_assert((E::word_size == 48), "");
615a83710eSEric Fiselier static_assert((E::short_lag == 5), "");
625a83710eSEric Fiselier static_assert((E::long_lag == 12), "");
63ae3c4eecSStephan T. Lavavej #if TEST_STD_VER >= 11
64ae3c4eecSStephan T. Lavavej static_assert((E::min() == 0), "");
65ae3c4eecSStephan T. Lavavej static_assert((E::max() == 0xFFFFFFFFFFFFull), "");
66ae3c4eecSStephan T. Lavavej #else
67ae3c4eecSStephan T. Lavavej assert((E::min() == 0));
68ae3c4eecSStephan T. Lavavej assert((E::max() == 0xFFFFFFFFFFFFull));
69ae3c4eecSStephan T. Lavavej #endif
705a83710eSEric Fiselier static_assert((E::default_seed == 19780503u), "");
715a83710eSEric Fiselier where(E::word_size);
725a83710eSEric Fiselier where(E::short_lag);
735a83710eSEric Fiselier where(E::long_lag);
745a83710eSEric Fiselier where(E::default_seed);
755a83710eSEric Fiselier }
765a83710eSEric Fiselier
main(int,char **)77*2df59c50SJF Bastien int main(int, char**)
785a83710eSEric Fiselier {
795a83710eSEric Fiselier test1();
805a83710eSEric Fiselier test2();
81*2df59c50SJF Bastien
82*2df59c50SJF Bastien return 0;
835a83710eSEric Fiselier }
84