chess:programming:prng_pseudo_random_number_generator:linear_congruential_generator
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
chess:programming:prng_pseudo_random_number_generator:linear_congruential_generator [2021/10/31 19:36] – peter | chess:programming:prng_pseudo_random_number_generator:linear_congruential_generator [2021/10/31 20:17] (current) – peter | ||
---|---|---|---|
Line 21: | Line 21: | ||
* To get started, the algorithm requires an initial Seed, which must be provided by some means. | * To get started, the algorithm requires an initial Seed, which must be provided by some means. | ||
* The appearance of randomness is provided by performing modulo arithmetic. | * The appearance of randomness is provided by performing modulo arithmetic. | ||
+ | |||
+ | ---- | ||
+ | |||
+ | <code cpp> | ||
+ | #include < | ||
+ | using namespace std; | ||
+ | |||
+ | int main() | ||
+ | { | ||
+ | int M = 8; | ||
+ | int a = 5; | ||
+ | int c = 3; | ||
+ | int X = 1; | ||
+ | int i; | ||
+ | | ||
+ | for(i=0; i<8; i++) | ||
+ | { | ||
+ | X = (a * X + c) % M; | ||
+ | std::cout << X << “ “; | ||
+ | } | ||
+ | return 0; | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | returns: | ||
+ | |||
+ | <code cpp> | ||
+ | 0 3 2 5 4 7 6 1 | ||
+ | </ | ||
+ | |||
+ | <WRAP info> | ||
+ | **NOTE: | ||
+ | |||
+ | * If we were to extend the loop we would find that this sequence would repeat over and over. | ||
+ | * This sequence happens to have a period of M, but other choices for a, and c could have smaller periods (a=3, c=3 has a period of 4). | ||
+ | |||
+ | To make this more useful we will need a large period. | ||
+ | |||
+ | * To do this we have to choose appropriate values for M, a, and c. | ||
+ | * To have a maximum period of M the following conditions must be met: | ||
+ | - M and c are Relatively Prime so the gcd(M, c) = 1. | ||
+ | - (a-1) is divisible by all prime factors of M. | ||
+ | - (a-1) mod 4 = 0 if (M mod 4) = 0 | ||
+ | |||
+ | </ | ||
+ | |||
---- | ---- | ||
Line 118: | Line 164: | ||
https:// | https:// | ||
+ | |||
+ | https:// | ||
+ | |||
+ | https:// | ||
+ | |||
+ | https:// | ||
+ | |||
chess/programming/prng_pseudo_random_number_generator/linear_congruential_generator.1635708985.txt.gz · Last modified: 2021/10/31 19:36 by peter