Namespace for MRG32k3a implementation details. More...
Classes | |
struct | Precalculated |
The transition matrices of the two MRG components (in matrix form), raised to all powers of 2 from 1 to 191. More... | |
Typedefs | |
typedef double | Matrix[3][3] |
Type for 3x3 matrix of doubles. More... | |
Functions | |
void | MatMatModM (const Matrix A, const Matrix B, Matrix C, double m) |
Compute the matrix C = A*B MOD m. More... | |
void | MatPowModM (const double A[3][3], double B[3][3], double m, int32_t n) |
Compute the matrix B = (A^n Mod m); works even if A = B. More... | |
void | MatTwoPowModM (const Matrix src, Matrix dst, double m, int32_t e) |
Compute the matrix B = (A^(2^e) Mod m); works also if A = B. More... | |
void | MatVecModM (const Matrix A, const double s[3], double v[3], double m) |
Compute the vector v = A*s MOD m. More... | |
double | MultModM (double a, double s, double c, double m) |
Return (a*s + c) MOD m; a, s, c and m must be < 2^35. More... | |
struct Precalculated | PowerOfTwoConstants (void) |
Compute the transition matrices of the two MRG components raised to all powers of 2 from 1 to 191. More... | |
void | PowerOfTwoMatrix (int n, Matrix a1p, Matrix a2p) |
Get the transition matrices raised to a power of 2. More... | |
Variables | |
const double | a12 = 1403580.0 |
First component multiplier of n - 2 value. More... | |
const double | a13n = 810728.0 |
First component multiplier of n - 3 value. More... | |
const Matrix | A1p0 |
First component transition matrix. More... | |
const double | a21 = 527612.0 |
Second component multiplier of n - 1 value. More... | |
const double | a23n = 1370589.0 |
Second component multiplier of n - 3 value. More... | |
const Matrix | A2p0 |
Second component transition matrix. More... | |
const double | m1 = 4294967087.0 |
First component modulus, 232 - 209. More... | |
const double | m2 = 4294944443.0 |
Second component modulus, 232 - 22853. More... | |
const double | norm = 1.0 / (m1 + 1.0) |
Normalization to obtain randoms on [0,1). More... | |
const double | two17 = 131072.0 |
Decomposition factor for computing a*s in less than 53 bits, 217 More... | |
const double | two53 = 9007199254740992.0 |
IEEE-754 floating point precision, 253 More... | |
Namespace for MRG32k3a implementation details.
typedef double MRG32k3a::Matrix[3][3] |
Type for 3x3 matrix of doubles.
Definition at line 55 of file rng-stream.cc.
Compute the matrix C = A*B MOD m.
Assume that -m < s[i] < m. Note: works also if A = C or B = C or A = B = C.
[in] | A | First matrix argument. |
[in] | B | Second matrix argument. |
[out] | C | Result matrix. |
[in] | m | Modulus. |
Definition at line 181 of file rng-stream.cc.
References MatVecModM().
Referenced by MatPowModM(), and MatTwoPowModM().
void MRG32k3a::MatPowModM | ( | const double | A[3][3], |
double | B[3][3], | ||
double | m, | ||
int32_t | n | ||
) |
Compute the matrix B = (A^n Mod m); works even if A = B.
[in] | A | Matrix input argument. |
[out] | B | Matrix output. |
[in] | m | Modulus. |
[in] | n | Exponent. |
Definition at line 248 of file rng-stream.cc.
References MatMatModM().
Compute the matrix B = (A^(2^e) Mod m); works also if A = B.
[in] | src | Matrix input argument A . |
[out] | dst | Matrix output B . |
[in] | m | Modulus. |
[in] | e | The exponent. |
Definition at line 219 of file rng-stream.cc.
References MatMatModM().
void MRG32k3a::MatVecModM | ( | const Matrix | A, |
const double | s[3], | ||
double | v[3], | ||
double | m | ||
) |
Compute the vector v = A*s MOD m.
Assume that -m < s[i] < m. Works also when v = s.
[in] | A | Matrix argument, 3x3. |
[in] | s | Three component input vector. |
[out] | v | Three component output vector. |
[in] | m | Modulus. |
Definition at line 152 of file rng-stream.cc.
References MultModM(), and sample-rng-plot::x.
Referenced by ns3::RngStream::AdvanceNthBy(), and MatMatModM().
double MRG32k3a::MultModM | ( | double | a, |
double | s, | ||
double | c, | ||
double | m | ||
) |
Return (a*s + c) MOD m; a, s, c and m must be < 2^35.
This computes the result exactly, without exceeding the 53 bit precision of doubles.
[in] | a | First multiplicative argument. |
[in] | s | Second multiplicative argument. |
[in] | c | Additive argument. |
[in] | m | Modulus. |
(a*s +c) MOD m
Definition at line 112 of file rng-stream.cc.
Referenced by MatVecModM().
struct Precalculated MRG32k3a::PowerOfTwoConstants | ( | void | ) |
Compute the transition matrices of the two MRG components raised to all powers of 2 from 1 to 191.
Definition at line 248 of file rng-stream.cc.
Referenced by PowerOfTwoMatrix().
Get the transition matrices raised to a power of 2.
[in] | n | The power of 2. |
[out] | a1p | The first transition matrix power. |
[out] | a2p | The second transition matrix power. |
Definition at line 313 of file rng-stream.cc.
References MRG32k3a::Precalculated::a1, MRG32k3a::Precalculated::a2, and PowerOfTwoConstants().
Referenced by ns3::RngStream::AdvanceNthBy().
const double MRG32k3a::a12 = 1403580.0 |
First component multiplier of n - 2 value.
Definition at line 67 of file rng-stream.cc.
Referenced by ns3::RngStream::RandU01().
const double MRG32k3a::a13n = 810728.0 |
First component multiplier of n - 3 value.
Definition at line 70 of file rng-stream.cc.
Referenced by ns3::RngStream::RandU01().
const Matrix MRG32k3a::A1p0 |
First component transition matrix.
Definition at line 85 of file rng-stream.cc.
const double MRG32k3a::a21 = 527612.0 |
Second component multiplier of n - 1 value.
Definition at line 73 of file rng-stream.cc.
Referenced by ns3::RngStream::RandU01().
const double MRG32k3a::a23n = 1370589.0 |
Second component multiplier of n - 3 value.
Definition at line 76 of file rng-stream.cc.
Referenced by ns3::RngStream::RandU01().
const Matrix MRG32k3a::A2p0 |
Second component transition matrix.
Definition at line 92 of file rng-stream.cc.
const double MRG32k3a::m1 = 4294967087.0 |
First component modulus, 232 - 209.
Definition at line 58 of file rng-stream.cc.
Referenced by PbbTestSuite::PbbTestSuite(), ns3::RngStream::RngStream(), ns3::RngStream::AdvanceNthBy(), UanTest::DoPhyTests(), and ns3::RngStream::RandU01().
const double MRG32k3a::m2 = 4294944443.0 |
Second component modulus, 232 - 22853.
Definition at line 61 of file rng-stream.cc.
Referenced by PbbTestSuite::PbbTestSuite(), ns3::RngStream::RngStream(), ns3::RngStream::AdvanceNthBy(), and ns3::RngStream::RandU01().
const double MRG32k3a::norm = 1.0 / (m1 + 1.0) |
Normalization to obtain randoms on [0,1).
Definition at line 64 of file rng-stream.cc.
Referenced by ns3::ThreeGppSpectrumPropagationLossModel::CalcBeamformingGain(), ns3::PhasedArrayModel::ComputeNorm(), ns3::PhasedArrayModel::GetBeamformingVector(), and ns3::RngStream::RandU01().
const double MRG32k3a::two17 = 131072.0 |
Decomposition factor for computing a*s in less than 53 bits, 217
Definition at line 79 of file rng-stream.cc.
Referenced by MultModM().
const double MRG32k3a::two53 = 9007199254740992.0 |
IEEE-754 floating point precision, 253
Definition at line 82 of file rng-stream.cc.
Referenced by MultModM().