Advertisement
_PoY

<<Mersenne Twister>>

Sep 12th, 2018
208
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 4.96 KB | None | 0 0
  1. /******************************************************************************
  2.  
  3. Online C Compiler.
  4. Code, Compile, Run and Debug C program online.
  5. Write your code in this editor and press "Run" button to compile and execute it.
  6.  
  7. *******************************************************************************/
  8.  
  9. #include <stdio.h>
  10.  
  11. /* Period parameters */
  12. #define N 624
  13. #define M 397
  14. #define MATRIX_A 0x9908b0dfUL /* constant vector a */
  15. #define UPPER_MASK 0x80000000UL /* most significant w-r bits */
  16. #define LOWER_MASK 0x7fffffffUL /* least significant r bits */
  17.  
  18. static unsigned long mt[N]; /* the array for the state vector */
  19. static int mti=N+1; /* mti==N+1 means mt[N] is not initialized */
  20.  
  21. void init_genrand(unsigned long s); //unsigned long seed;
  22. void init_by_array(unsigned long init_key[], int key_length);
  23. unsigned long genrand_int32(void);
  24.  
  25.  
  26. int main()
  27. {
  28. unsigned int seed = 0x0F0E0E65;
  29. unsigned int MULT = 0x41C64E6D, ADD = 0x6073;
  30.  
  31. int loop, loopNb = 4;
  32. int rng = seed;
  33. for(loop = 0; loop < loopNb; loop++){
  34. rng = rng * MULT + ADD;
  35. }
  36. printf("LID: %5d\n",rng/65536);
  37.  
  38. init_genrand(seed);
  39. unsigned long mersenne;
  40. int mersenneLoopNb = 2;
  41. for(loop = 0; loop < mersenneLoopNb; loop++){
  42. mersenne = genrand_int32();
  43. }
  44.  
  45. printf("TID: %5d\n", mersenne%65536);
  46.  
  47. return 0;
  48. }
  49.  
  50.  
  51.  
  52. /* initializes mt[N] with a seed */
  53. void init_genrand(unsigned long s)
  54. {
  55. mt[0]= s & 0xffffffffUL;
  56. for (mti=1; mti<N; mti++) {
  57. mt[mti] =
  58. (1812433253UL * (mt[mti-1] ^ (mt[mti-1] >> 30)) + mti);
  59. /* See Knuth TAOCP Vol2. 3rd Ed. P.106 for multiplier. */
  60. /* In the previous versions, MSBs of the seed affect */
  61. /* only MSBs of the array mt[]. */
  62. /* 2002/01/09 modified by Makoto Matsumoto */
  63. mt[mti] &= 0xffffffffUL;
  64. /* for >32 bit machines */
  65. }
  66. }
  67.  
  68. /* initialize by an array with array-length */
  69. /* init_key is the array for initializing keys */
  70. /* key_length is its length */
  71. /* slight change for C++, 2004/2/26 */
  72. void init_by_array(unsigned long init_key[], int key_length)
  73. {
  74. int i, j, k;
  75. init_genrand(19650218UL);
  76. i=1; j=0;
  77. k = (N>key_length ? N : key_length);
  78. for (; k; k--) {
  79. mt[i] = (mt[i] ^ ((mt[i-1] ^ (mt[i-1] >> 30)) * 1664525UL))
  80. + init_key[j] + j; /* non linear */
  81. mt[i] &= 0xffffffffUL; /* for WORDSIZE > 32 machines */
  82. i++; j++;
  83. if (i>=N) { mt[0] = mt[N-1]; i=1; }
  84. if (j>=key_length) j=0;
  85. }
  86. for (k=N-1; k; k--) {
  87. mt[i] = (mt[i] ^ ((mt[i-1] ^ (mt[i-1] >> 30)) * 1566083941UL))
  88. - i; /* non linear */
  89. mt[i] &= 0xffffffffUL; /* for WORDSIZE > 32 machines */
  90. i++;
  91. if (i>=N) { mt[0] = mt[N-1]; i=1; }
  92. }
  93.  
  94. mt[0] = 0x80000000UL; /* MSB is 1; assuring non-zero initial array */
  95. }
  96.  
  97. /* generates a random number on [0,0xffffffff]-interval */
  98. unsigned long genrand_int32(void)
  99. {
  100. unsigned long y;
  101. static unsigned long mag01[2]={0x0UL, MATRIX_A};
  102. /* mag01[x] = x * MATRIX_A for x=0,1 */
  103.  
  104. if (mti >= N) { /* generate N words at one time */
  105. int kk;
  106.  
  107. if (mti == N+1) /* if init_genrand() has not been called, */
  108. init_genrand(5489UL); /* a default initial seed is used */
  109.  
  110. for (kk=0;kk<N-M;kk++) {
  111. y = (mt[kk]&UPPER_MASK)|(mt[kk+1]&LOWER_MASK);
  112. mt[kk] = mt[kk+M] ^ (y >> 1) ^ mag01[y & 0x1UL];
  113. }
  114. for (;kk<N-1;kk++) {
  115. y = (mt[kk]&UPPER_MASK)|(mt[kk+1]&LOWER_MASK);
  116. mt[kk] = mt[kk+(M-N)] ^ (y >> 1) ^ mag01[y & 0x1UL];
  117. }
  118. y = (mt[N-1]&UPPER_MASK)|(mt[0]&LOWER_MASK);
  119. mt[N-1] = mt[M-1] ^ (y >> 1) ^ mag01[y & 0x1UL];
  120.  
  121. mti = 0;
  122. }
  123.  
  124. y = mt[mti++];
  125.  
  126. /* Tempering */
  127. y ^= (y >> 11);
  128. y ^= (y << 7) & 0x9d2c5680UL;
  129. y ^= (y << 15) & 0xefc60000UL;
  130. y ^= (y >> 18);
  131.  
  132. return y;
  133. }
  134.  
  135. /* generates a random number on [0,0x7fffffff]-interval */
  136. long genrand_int31(void)
  137. {
  138. return (long)(genrand_int32()>>1);
  139. }
  140.  
  141. /* generates a random number on [0,1]-real-interval */
  142. double genrand_real1(void)
  143. {
  144. return genrand_int32()*(1.0/4294967295.0);
  145. /* divided by 2^32-1 */
  146. }
  147.  
  148. /* generates a random number on [0,1)-real-interval */
  149. double genrand_real2(void)
  150. {
  151. return genrand_int32()*(1.0/4294967296.0);
  152. /* divided by 2^32 */
  153. }
  154.  
  155. /* generates a random number on (0,1)-real-interval */
  156. double genrand_real3(void)
  157. {
  158. return (((double)genrand_int32()) + 0.5)*(1.0/4294967296.0);
  159. /* divided by 2^32 */
  160. }
  161.  
  162. /* generates a random number on [0,1) with 53-bit resolution*/
  163. double genrand_res53(void)
  164. {
  165. unsigned long a=genrand_int32()>>5, b=genrand_int32()>>6;
  166. return(a*67108864.0+b)*(1.0/9007199254740992.0);
  167. }
  168. /* These real versions are due to Isaku Wada, 2002/01/09 added */
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement