]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/std/numerics/rand/rand.eng/rand.eng.mers/discard.pass.cpp
Vendor import of libc++ trunk r351319 (just before the release_80
[FreeBSD/FreeBSD.git] / test / std / numerics / rand / rand.eng / rand.eng.mers / discard.pass.cpp
1 //===----------------------------------------------------------------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 // <random>
11
12 // template <class UIntType, size_t w, size_t n, size_t m, size_t r,
13 //           UIntType a, size_t u, UIntType d, size_t s,
14 //           UIntType b, size_t t, UIntType c, size_t l, UIntType f>
15 // class mersenne_twister_engine;
16
17 // void discard(unsigned long long z);
18
19 #include <random>
20 #include <sstream>
21 #include <cassert>
22
23 void
24 test1()
25 {
26     std::mt19937 e1;
27     std::mt19937 e2 = e1;
28     assert(e1 == e2);
29     e1.discard(3);
30     assert(e1 != e2);
31     (void)e2();
32     (void)e2();
33     (void)e2();
34     assert(e1 == e2);
35 }
36
37 void
38 test2()
39 {
40     std::mt19937_64 e1;
41     std::mt19937_64 e2 = e1;
42     assert(e1 == e2);
43     e1.discard(3);
44     assert(e1 != e2);
45     (void)e2();
46     (void)e2();
47     (void)e2();
48     assert(e1 == e2);
49 }
50
51 int main()
52 {
53     test1();
54     test2();
55 }