source: xplcommon/src/xplcommon/PseudoRandom.cc@ 27:11b3ec33029d

Last change on this file since 27:11b3ec33029d was 27:11b3ec33029d, checked in by István Váradi <ivaradi@…>, 11 years ago

Implemented a pseudo-random number generator

File size: 2.6 KB
Line 
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 "PseudoRandom.h"
33
34//------------------------------------------------------------------------------
35
36using xplcommon::PseudoRandom;
37
38//------------------------------------------------------------------------------
39
40void PseudoRandom::initialize(uint32_t seed)
41{
42 vector[0] = seed;
43 for(size_t i = 1; i<vectorSize-3; ++i) {
44 int32_t x = (static_cast<long long>(16807) *
45 static_cast<long long>(vector[i-1])) % 2147483647;
46 if (x<0) x += 2147483647;
47 vector[i] = x;
48 }
49 for(size_t i = vectorSize - 3; i<vectorSize; ++i) {
50 vector[i] = vector[i-31];
51 }
52
53 nextIndex = 0;
54
55 for(size_t i = vectorSize; i<numDiscarded; ++i) {
56 next();
57 }
58}
59
60//------------------------------------------------------------------------------
61
62// Local Variables:
63// mode: C++
64// c-basic-offset: 4
65// indent-tabs-mode: nil
66// End:
Note: See TracBrowser for help on using the repository browser.