]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/testsuite/tr1/5_numerical_facilities/random/ranlux3_01.cc
Update copyright years.
[thirdparty/gcc.git] / libstdc++-v3 / testsuite / tr1 / 5_numerical_facilities / random / ranlux3_01.cc
CommitLineData
9aa53350
PC
1// 2006-08-22 Paolo Carlini <pcarlini@suse.de>
2//
7adcbafe 3// Copyright (C) 2006-2022 Free Software Foundation, Inc.
9aa53350
PC
4//
5// This file is part of the GNU ISO C++ Library. This library is free
6// software; you can redistribute it and/or modify it under the
7// terms of the GNU General Public License as published by the
748086b7 8// Free Software Foundation; either version 3, or (at your option)
9aa53350
PC
9// any later version.
10//
11// This library is distributed in the hope that it will be useful,
12// but WITHOUT ANY WARRANTY; without even the implied warranty of
13// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14// GNU General Public License for more details.
15//
16// You should have received a copy of the GNU General Public License along
748086b7
JJ
17// with this library; see the file COPYING3. If not see
18// <http://www.gnu.org/licenses/>.
9aa53350
PC
19
20// 5.1.5 Engines with predefined parameters
21// 5.1.5 [3]
22
23#include <iostream>
24#include <tr1/random>
25#include <testsuite_hooks.h>
26
27void
f92ab29f 28test01()
9aa53350 29{
9aa53350
PC
30 std::tr1::ranlux3_01 a;
31 for (int i = 0; i < 9999; ++i)
32 a();
33
34#if _GLIBCXX_USE_C99_MATH_TR1
35 VERIFY( a() == 5957620 * std::tr1::ldexp(float(1), -24) );
36#else
37 VERIFY( a() == 5957620 * std::pow(float(2), -24) );
38#endif
39}
40
41int main()
42{
43 test01();
44 return 0;
45}