//===----------------------------------------------------------------------===//
//
//                     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>();
}