//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // template // class linear_congruential_engine // { // public: // engine characteristics // static constexpr result_type multiplier = a; // static constexpr result_type increment = c; // static constexpr result_type modulus = m; // static constexpr result_type min() { return c == 0u ? 1u: 0u;} // static constexpr result_type max() { return m - 1u;} // static constexpr result_type default_seed = 1u; #include #include #include #include #include "test_macros.h" template void where(const T &) {} template void test1() { typedef std::linear_congruential_engine LCE; typedef typename LCE::result_type result_type; static_assert((LCE::multiplier == a), ""); static_assert((LCE::increment == c), ""); static_assert((LCE::modulus == m), ""); #if TEST_STD_VER >= 11 static_assert((LCE::min() == (c == 0u ? 1u: 0u)), ""); #else assert((LCE::min() == (c == 0u ? 1u: 0u))); #endif TEST_DIAGNOSTIC_PUSH TEST_MSVC_DIAGNOSTIC_IGNORED(4310) // cast truncates constant value #if TEST_STD_VER >= 11 static_assert((LCE::max() == result_type(m - 1u)), ""); #else assert((LCE::max() == result_type(m - 1u))); #endif TEST_DIAGNOSTIC_POP static_assert((LCE::default_seed == 1), ""); where(LCE::multiplier); where(LCE::increment); where(LCE::modulus); where(LCE::default_seed); } template void test() { const int W = sizeof(T) * CHAR_BIT; const T M(static_cast(-1)); const T A(static_cast((static_cast(1) << (W / 2)) - 1)); // Cases where m = 0 test1(); test1(); test1(); test1(); // Cases where m = 2^n for n < w test1(); test1(); test1(); test1(); // Cases where m is odd and a = 0 test1(); test1(); test1(); // Cases where m is odd and m % a <= m / a (Schrage) test1(); test1(); test1(); } template void test_ext() { const T M(static_cast(-1)); // Cases where m is odd and m % a > m / a test1(); test1(); test1(); test1(); test1(); test1(); } int main(int, char**) { test(); test_ext(); test(); test_ext(); test(); test_ext(); test(); // This isn't implemented on platforms without __int128 #ifndef TEST_HAS_NO_INT128 test_ext(); #endif return 0; }