CLHEP 2.4.6.4
C++ Class Library for High Energy Physics
Loading...
Searching...
No Matches
DualRand.h
Go to the documentation of this file.
1// $Id: DualRand.h,v 1.5 2010/06/16 17:24:53 garren Exp $
2// -*- C++ -*-
3//
4// -----------------------------------------------------------------------
5// Hep Random
6// --- DualRand ---
7// class header file
8// -----------------------------------------------------------------------
9//
10// Canopy random number generator DualRand
11// Re-written as C++ routine for 32-bit ints MF 1/26/98
12//
13// Exclusive or of a feedback shift register and integer congruence
14// random number generator. The feedback shift register uses offsets
15// 127 and 97. The integer congruence generator uses a different
16// multiplier for each stream. The multipliers are chosen to give
17// full period and maximum "potency" for modulo 2^32. The period of
18// the combined random number generator is 2^159 - 2^32, and the
19// sequences are different for each stream (not just started in a
20// different place).
21//
22// =======================================================================
23// Canopy random number generator DualRand.
24// Doug Toussaint 5/25/88
25// Optimized by GMH 7/26/88
26// Optimized by GMH 7/26/88
27// Repaired by GMH 12/1/88 to update modular congruence state
28// Put into ranlib by GMH 6/23/89
29// Re-written as C++ routine for 32-bit ints MF 1/26/98
30// Re-written for CLHEP package KLS 6/04/98
31// Removed pow() from flat method for speed KLS 7/21/98
32// Ken Smith - Added conversion operators: 6th Aug 1998
33// Mark Fischler methods for distrib. instance save/restore 12/8/04
34// Mark Fischler methods for anonymous save/restore 12/27/04
35// Mark Fischler - methods for vector save/restore 3/7/05
36// =======================================================================
37
38
39#ifndef DualRand_h
40#define DualRand_h
41
42#include "CLHEP/Random/defs.h"
43#include "CLHEP/Random/RandomEngine.h"
44
45namespace CLHEP {
46
47/**
48 * @author
49 * @ingroup random
50 */
52
53public:
54
55 DualRand();
56 DualRand(long seed);
57 DualRand(std::istream & is);
58 DualRand(int rowIndex, int colIndex);
59 virtual ~DualRand();
60
61 // let the compiler generate the copy constructors
62 //DualRand(const DualRand & p);
63 //DualRand & operator=(const DualRand & p);
64
65 double flat();
66 // Returns a pseudo random number between 0 and 1
67 // (excluding the end points)
68
69 void flatArray(const int size, double * vect);
70 // Fills an array "vect" of specified size with flat random values.
71
72 void setSeed(long seed, int);
73 // Sets the state of the algorithm according to seed.
74
75 void setSeeds(const long * seeds, int);
76 // Sets the state of the algorithm according to the zero-terminated
77 // array of seeds.
78
79 void saveStatus( const char filename[] = "DualRand.conf") const;
80 // Saves on named file the current engine status.
81
82 void restoreStatus( const char filename[] = "DualRand.conf" );
83 // Reads from named file the last saved engine status and restores it.
84
85 void showStatus() const;
86 // Dumps the current engine status on the screen.
87
88 operator double(); // Returns same as flat()
89 operator float(); // flat value, without worrying about filling bits
90 operator unsigned int(); // 32-bit flat value, quickest of all
91
92 virtual std::ostream & put (std::ostream & os) const;
93 virtual std::istream & get (std::istream & is);
94 static std::string beginTag ( );
95 virtual std::istream & getState ( std::istream & is );
96
97 std::string name() const;
98 static std::string engineName() {return "DualRand";}
99
100 std::vector<unsigned long> put () const;
101 bool get (const std::vector<unsigned long> & v);
102 bool getState (const std::vector<unsigned long> & v);
103
104 static const unsigned int VECTOR_STATE_SIZE = 9;
105
106private:
107
108 // This generator is composed of two others combined:
109
110 class Tausworthe {
111 public:
112 Tausworthe();
113 Tausworthe(unsigned int seed);
114 operator unsigned int();
115 void put(std::ostream & os) const;
116 void put(std::vector<unsigned long> & v) const;
117 void get(std::istream & is);
118 bool get(std::vector<unsigned long>::const_iterator & iv);
119 private:
120 int wordIndex;
121 unsigned int words[4];
122 }; // Tausworthe
123
124 class IntegerCong {
125 public:
126 IntegerCong();
127 IntegerCong(unsigned int seed, int streamNumber);
128 operator unsigned int();
129 void put(std::ostream & os) const;
130 void put(std::vector<unsigned long> & v) const;
131 void get(std::istream & is);
132 bool get(std::vector<unsigned long>::const_iterator & iv);
133 private:
134 unsigned int state, multiplier, addend;
135 }; // IntegerCong
136
137 int numEngines;
138 Tausworthe tausworthe;
139 IntegerCong integerCong;
140
141}; // DualRand
142
143} // namespace CLHEP
144
145#ifdef ENABLE_BACKWARDS_COMPATIBILITY
146// backwards compatibility will be enabled ONLY in CLHEP 1.9
147using namespace CLHEP;
148#endif
149
150#endif // DualRand_h
std::string name() const
Definition: DualRand.cc:73
void setSeeds(const long *seeds, int)
Definition: DualRand.cc:138
void showStatus() const
Definition: DualRand.cc:207
std::vector< unsigned long > put() const
Definition: DualRand.cc:257
static const unsigned int VECTOR_STATE_SIZE
Definition: DualRand.h:104
void restoreStatus(const char filename[]="DualRand.conf")
Definition: DualRand.cc:172
virtual ~DualRand()
Definition: DualRand.cc:115
void setSeed(long seed, int)
Definition: DualRand.cc:132
void saveStatus(const char filename[]="DualRand.conf") const
Definition: DualRand.cc:143
void flatArray(const int size, double *vect)
Definition: DualRand.cc:126
virtual std::istream & get(std::istream &is)
Definition: DualRand.cc:265
static std::string engineName()
Definition: DualRand.h:98
double flat()
Definition: DualRand.cc:117
virtual std::istream & getState(std::istream &is)
Definition: DualRand.cc:286
static std::string beginTag()
Definition: DualRand.cc:282
#define double(obj)
Definition: excDblThrow.cc:32