//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // <random> // template <class UIntType, UIntType a, UIntType c, UIntType m> // class linear_congruential_engine; // result_type operator()(); #include <random> #include <cassert> template <class T> void randu() { typedef std::linear_congruential_engine<T, 65539, 0, 2147483648u> E; E e(1); assert(e() == 65539); assert(e() == 393225); assert(e() == 1769499); assert(e() == 7077969); assert(e() == 26542323); assert(e() == 95552217); assert(e() == 334432395); assert(e() == 1146624417); assert(e() == 1722371299); assert(e() == 14608041); assert(e() == 1766175739); assert(e() == 1875647473); } template <class T> void minstd() { typedef std::linear_congruential_engine<T, 16807, 0, 2147483647> E; E e(1); assert(e() == 16807); assert(e() == 282475249); assert(e() == 1622650073); assert(e() == 984943658); assert(e() == 1144108930); assert(e() == 470211272); assert(e() == 101027544); assert(e() == 1457850878); assert(e() == 1458777923); assert(e() == 2007237709); assert(e() == 823564440); assert(e() == 1115438165); } template <class T> void Haldir() { typedef std::linear_congruential_engine<T, 16807, 78125, 2147483647> E; E e(207560540); assert(e() == 956631177); assert(e() == 2037688522); assert(e() == 1509348670); assert(e() == 1546336451); assert(e() == 429714088); assert(e() == 217250280); } int main() { randu<unsigned int>(); randu<unsigned long>(); randu<unsigned long long>(); minstd<unsigned int>(); minstd<unsigned long>(); minstd<unsigned long long>(); Haldir<unsigned int>(); Haldir<unsigned long>(); Haldir<unsigned long long>(); }