69#ifdef R__COMPLETE_MEM_TERMINATION
71 struct TRandomCleanup {
74 static TRandomCleanup gCleanupRandom;
89 SetTitle(
"Random number generator: Mersenne Twister");
111 const Int_t kM = 397;
112 const Int_t kN = 624;
113 const UInt_t kTemperingMaskB = 0x9d2c5680;
114 const UInt_t kTemperingMaskC = 0xefc60000;
115 const UInt_t kUpperMask = 0x80000000;
116 const UInt_t kLowerMask = 0x7fffffff;
117 const UInt_t kMatrixA = 0x9908b0df;
122 for (i=0; i < kN-kM; i++) {
123 y = (
fMt[i] & kUpperMask) | (
fMt[i+1] & kLowerMask);
124 fMt[i] =
fMt[i+kM] ^ (
y >> 1) ^ ((
y & 0x1) ? kMatrixA : 0x0);
127 for ( ; i < kN-1 ; i++) {
128 y = (
fMt[i] & kUpperMask) | (
fMt[i+1] & kLowerMask);
129 fMt[i] =
fMt[i+kM-kN] ^ (
y >> 1) ^ ((
y & 0x1) ? kMatrixA : 0x0);
132 y = (
fMt[kN-1] & kUpperMask) | (
fMt[0] & kLowerMask);
133 fMt[kN-1] =
fMt[kM-1] ^ (
y >> 1) ^ ((
y & 0x1) ? kMatrixA : 0x0);
139 y ^= ((
y << 7 ) & kTemperingMaskB );
140 y ^= ((
y << 15) & kTemperingMaskC );
144 if (
y)
return ( (
Double_t)
y * 2.3283064365386963e-10);
165 const Int_t kM = 397;
166 const Int_t kN = 624;
167 const UInt_t kTemperingMaskB = 0x9d2c5680;
168 const UInt_t kTemperingMaskC = 0xefc60000;
169 const UInt_t kUpperMask = 0x80000000;
170 const UInt_t kLowerMask = 0x7fffffff;
171 const UInt_t kMatrixA = 0x9908b0df;
177 for (i=0; i < kN-kM; i++) {
178 y = (
fMt[i] & kUpperMask) | (
fMt[i+1] & kLowerMask);
179 fMt[i] =
fMt[i+kM] ^ (
y >> 1) ^ ((
y & 0x1) ? kMatrixA : 0x0);
182 for ( ; i < kN-1 ; i++) {
183 y = (
fMt[i] & kUpperMask) | (
fMt[i+1] & kLowerMask);
184 fMt[i] =
fMt[i+kM-kN] ^ (
y >> 1) ^ ((
y & 0x1) ? kMatrixA : 0x0);
187 y = (
fMt[kN-1] & kUpperMask) | (
fMt[0] & kLowerMask);
188 fMt[kN-1] =
fMt[kM-1] ^ (
y >> 1) ^ ((
y & 0x1) ? kMatrixA : 0x0);
194 y ^= ((
y << 7 ) & kTemperingMaskB );
195 y ^= ((
y << 15) & kTemperingMaskC );
199 array[k] =
Double_t(
y * 2.3283064365386963e-10);
224 for(
Int_t i=1; i<624; i++) {
225 fMt[i] = (1812433253 * (
fMt[i-1] ^ (
fMt[i-1] >> 30)) + i );
234 for (
Int_t i = 0; i< 624; i++) {
235 fMt[i] =
static_cast<UInt_t> (4294967296.*
r.Rndm());
int Int_t
Signed integer 4 bytes (int).
short Version_t
Class version identifier (short).
unsigned int UInt_t
Unsigned integer 4 bytes (unsigned int).
unsigned long ULong_t
Unsigned long integer 4 bytes (unsigned long). Size depends on architecture.
double Double_t
Double 8 bytes.
float Float_t
Float 4 bytes (float).
Buffer base class used for serializing objects.
virtual Version_t ReadVersion(UInt_t *start=nullptr, UInt_t *bcnt=nullptr, const TClass *cl=nullptr)=0
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
virtual Int_t ReadClassBuffer(const TClass *cl, void *pointer, const TClass *onfile_class=nullptr)=0
virtual Int_t ReadStaticArray(Bool_t *b)=0
virtual Int_t WriteClassBuffer(const TClass *cl, void *pointer)=0
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
virtual void SetName(const char *name)
Set the name of the TNamed.
Random number generator class based on the maximally equidistributed combined Tausworthe generator by...
Random number generator class based on M.
Double_t Rndm() override
Machine independent random number generator.
void RndmArray(Int_t n, Float_t *array) override
Return an array of n random numbers uniformly distributed in ]0, 1[.
TClass * IsA() const override
TRandom3(UInt_t seed=4357)
Default constructor.
void Streamer(TBuffer &) override
Streamer for an object of class TRandom3.
~TRandom3() override
Default destructor.
void SetSeed(ULong_t seed=0) override
Set the random generator sequence.
This is the base class for the ROOT Random number generators.
virtual void SetSeed(ULong_t seed=0)
Set the random generator seed.
void Streamer(TBuffer &) override
Stream an object of class TObject.