Metoda congruentă inversă

Versiunea actuală a paginii nu a fost încă examinată de colaboratori experimentați și poate diferi semnificativ de versiunea revizuită la 30 aprilie 2020; verificările necesită 3 modificări .

Metoda congruențială inversă (sau generatorul Eichenauer-Lehn , eventual și Eichenauer-Lehn ) este o metodă de generare a numerelor pseudoaleatoare bazată pe utilizarea numărului modulo invers pentru a genera următorul membru al secvenței.

Descriere

Metoda congruențială inversă a fost propusă de Eichenauer și Lehn în 1986 [1] ca înlocuitor pentru metoda congruențială liniară non-latice [2] .

Această metodă constă în calcularea unei succesiuni de numere aleatorii din inelul de reziduuri modulo un număr natural .

Principala diferență față de metoda liniară este că atunci când se generează o secvență, se folosește numărul invers față de elementul anterior în locul elementului anterior în sine.

Parametrii generatorului sunt [3] :

 - sare
 - multiplicator
 - increment

În cazul unui n simplu

Valoarea membrilor secvenței este dată astfel:

  dacă
dacă

În cazul compozitului n

Dacă numărul este compus, elementele șirului se calculează după cum urmează:

 

Parametrii sunt aleși în așa fel încât .

Perioada

Secvența este periodică, iar perioada nu depășește dimensiunea inelului . Perioada maximă este atinsă dacă polinomul este primitiv . O condiție suficientă pentru perioada maximă a secvenței este o astfel de alegere a constantelor și ca polinomul să fie ireductibil [4] .

În cazul unui compus, perioada maximă posibilă este ( funcția Euler ) [5] .

Exemplu

Generatorul congruențial invers cu parametri generează o secvență în inel , unde numerele și , precum și și sunt inverse unul față de celălalt. În acest exemplu, polinomul este ireductibil în și numerele nu sunt rădăcinile sale, datorită cărora perioada este maximă și egală cu .

Exemple de implementare

Python

Codul def egcd ( a , b ): if a == 0 : return ( b , 0 , 1 ) else : g , y , x = egcd ( b % a , a ) return ( g , x - ( b // a ) * y , y ) def modinv ( a , m ): gcd , x , y = egcd ( a , m ) if gcd != 1 : return None # inversul modular nu există altfel : returnează x % m def ICG ( n , a , c , seed ): if ( seed == 0 ): return c return ( a * modinv ( seed , n ) + c ) % n sămânță = 1 n = 5 a = 2 c = 3 număr = 10 pentru i în interval ( număr ): imprimare ( seed ) seed = ICG ( n , a , c , seed )

C++

Codul #include <iostream> folosind namespace std ; int mod_inv ( int a , int n ) { int b0 = n , t , q ; int x0 = 0 , x1 = 1 ; dacă ( n == 1 ) returnează 1 ; în timp ce ( a > 1 ) { q = a / n ; t = n , n = a % n , a = t ; t = x0 , x0 = x1 - q * x0 , x1 = t ; } dacă ( x1 < 0 ) x1 += b0 ; întoarcere x1 ; } int ICG ( int n , int a , int c , int seed ) { dacă ( sămânță == 0 ) returnează c ; return ( a * mod_inv ( seed , n ) + c ) % n ; } int main ( void ) { int samanta = 1 ; int n = 5 ; int a = 2 ; int c = 3 ; număr int = 10 ; pentru ( int i = 0 ; i < număr ; i ++ ) { cout << sămânță << endl ; sămânță = ICG ( n , a , c , sămânță ); } returnează 0 ; }

Generatoare inverse compozite

Principalul dezavantaj al generatoarelor congruențiale inverse este creșterea complexității de calcul cu creșterea perioadei. Acest neajuns este corectat în generatoarele compuși congruențiale inverse.

Construcția generatoarelor inverse compozite este o combinație de două sau mai multe generatoare inverse congruente.

Fie  numere prime distincte, fiecare . Pentru fiecare index din , fie  o succesiune de elemente cu punct . Cu alte cuvinte, .

Fie  o succesiune de numere aleatoare în , unde .

Secvența rezultată este definită ca suma: .

Perioada secvenței rezultate [6] .

Unul dintre avantajele acestei abordări este capacitatea de a utiliza generatoare congruențiale inverse care rulează în paralel.

Un exemplu de generator invers compus

Lasă și . Pentru simplitate, să punem și . Pentru fiecare calculăm .

Apoi . Adică avem o secvență cu punct .

Pentru a scăpa de numerele fracționale, putem înmulți fiecare element al șirului rezultat și obținem o secvență de numere întregi:

Beneficiile generatoarelor congruențiale inverse

Generatoarele congruențiale inverse sunt utilizate în scopuri practice din mai multe motive.

În primul rând, generatoarele congruente inverse au o uniformitate destul de bună [7] , în plus, secvențele rezultate sunt complet lipsite de structura rețelei caracteristică generatoarelor congruente liniare [1] [8] [9] .

În al doilea rând, secvențele binare obținute folosind ICG nu au abateri statistice nedorite. Secvențele obținute prin această metodă au fost verificate printr-un număr de teste statistice și rămân stabile cu modificarea parametrilor [7] [8] [10] [11] .

În al treilea rând, oscilatorii compuși au aceleași proprietăți ca și oscilatorii liniari unici invers [12] , dar în același timp au o perioadă care depășește semnificativ perioada oscilatoarelor unice [13] . În plus, dispozitivul generatoarelor compozite permite obținerea unei creșteri de performanță ridicate atunci când este utilizat pe sisteme multiprocesor [14] .

Există un algoritm care permite dezvoltarea unor generatoare compozite cu lungimea perioadei și complexitatea previzibile, precum și proprietăți statistice bune ale secvențelor de ieșire [15] .

Dezavantajele generatoarelor congruențiale inverse

Principalul dezavantaj al generatoarelor congruențiale inverse este viteza lentă de generare a elementelor secvenței: calculul unui element al secvenței necesită operații de înmulțire [16] .

Note

  1. 1 2 Knut, 2013 , p. 45.
  2. Eichenauer, Lehn, 1986 .
  3. Hellekalek, 1995 , p. 255: „Trebuie să alegem modulul p, un multiplicator a, un termen aditiv b”.
  4. Amy Glen: On the Period Length of Pseudorandom Number Sequences, 2002 , 5.3, p. 67: „Dacă x2-bx-a este un polinom primitiv peste Fp, atunci Xi are perioada completă p”.
  5. Amy Glen: On the Period Length of Pseudorandom Number Sequences, 2002 , 5.4, p. 69: „Secvența Xi este pur periodică cu lungimea perioadei d ≤ φ(m)”.
  6. Hellekalek, 1995 , p. 256: „Este elementar să vedem că perioada șirului (Xn)n este egală cu M := p1*p2*...* pr”.
  7. 1 2 Eichenauer-Herrmann, Niederreiter, 1992 .
  8. 1 2 Eichenauer-Herrmann, 1991 .
  9. Eichenauer-Herrmann, Grothe, Niederreiter et al, 1990 , p. 81: „Acești generatori nu arată structura simplă de rețea a generatoarelor congruențiale liniare utilizate pe scară largă”.
  10. Eichenauer-Herrmann, 1993 .
  11. Hellekalek, 1995 , p. 261: „Excelentele proprietăți teoretice și empirice ale metodelor inversive rămân stabile sub variația parametrilor, cu condiția să avem lungimea maximă a perioadei”.
  12. Bubicz, Stoklosa, 2006 , p. 2: „Abordarea compusă oferă aceleași proprietăți remarcabile ale secvențelor produse ca și generatoarele inversive unice”.
  13. Bubicz, Stoklosa, 2006 , p. 2: „Generatoarele inversive compuși permit obținerea unei perioade semnificativ mai mari decât cea obținută de un singur ICG”.
  14. Bubicz, Stoklosa, 2006 , p. 2: „Par a fi proiectate pentru aplicații cu platforme hardware paralele cu multiprocesor.”
  15. Bubicz, Stoklosa, 2006 , p. 2: „Există o modalitate constantă și simplă de alegere a parametrilor, bazată pe algoritmul Chou. Acesta garantează lungimea maximă”.
  16. Anne Gille-Genest: Pseudo-Random Numbers Generators, 2012 , p. 12: „Principalul dezavantaj al acelor ambele generatoare inverse este că un calcul al unui număr aleatoriu necesită înmulțirea O(log m ) în Fm , astfel încât algoritmul nu este rapid.”

Literatură

Cărți
  • Knut D. E. The Art of Programming : Volumul 2. Obtained Algorithms - 3 - M . : Williams , 2013. - 828 p. — ISBN 978-5-8459-0081-4
Articole