source: vscpl/test/testrandom.cc@ 38:40ce1c761f69

Last change on this file since 38:40ce1c761f69 was 11:8896990dfd4a, checked in by István Váradi <ivaradi@…>, 12 years ago

Imported the test program for the pseudo-random number generator

File size: 2.6 KB
RevLine 
[11]1// Copyright (c) 2013 by István Váradi
2
3// This file is part of libxplcommon, a common utility library for
4// development related to X-Plane
5
6// Redistribution and use in source and binary forms, with or without
7// modification, are permitted provided that the following conditions are met:
8
9// 1. Redistributions of source code must retain the above copyright notice, this
10// list of conditions and the following disclaimer.
11// 2. Redistributions in binary form must reproduce the above copyright notice,
12// this list of conditions and the following disclaimer in the documentation
13// and/or other materials provided with the distribution.
14
15// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
19// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
26// The views and conclusions contained in the software and documentation are those
27// of the authors and should not be interpreted as representing official policies,
28// either expressed or implied, of the FreeBSD Project.
29
30//------------------------------------------------------------------------------
31
32#include <hu/varadiistvan/scpl/PseudoRandom.h>
33
34#include <cstdio>
35#include <ctime>
36#include <cstdlib>
37
38//------------------------------------------------------------------------------
39
40using hu::varadiistvan::scpl::PseudoRandom;
41
42//------------------------------------------------------------------------------
43
44int main(int argc, char* argv[])
45{
46 unsigned int seed = (argc>1) ? atoi(argv[1]) : time(0);
47
48 printf("seed=%u\n", seed);
49
50 srand(seed);
51 PseudoRandom pr(seed);
52 for(size_t i = 0; i<10000; ++i) {
53 int r1 = rand();
54 int r2 = pr.next();
55 if (r1!=r2) {
56 printf("values at i=%zu differ: rand(): %d, PseudoRandom: %d\n",
57 i, r1, r2);
58 break;
59 }
60 }
61}
62
63//------------------------------------------------------------------------------
64
65// Local Variables:
66// mode: C++
67// c-basic-offset: 4
68// indent-tabs-mode: nil
69// End:
Note: See TracBrowser for help on using the repository browser.