Generátor pseudonáhodných čísel - Pseudorandom number generator
A generátor pseudonáhodných čísel (PRNG), také známý jako a deterministický generátor náhodných bitů (DRBG),[1] je algoritmus pro generování posloupnosti čísel, jejichž vlastnosti se blíží vlastnostem posloupnosti náhodná čísla. Sekvence generovaná PRNG není skutečně náhodný, protože je zcela určena počáteční hodnotou, která se nazývá PRNG semínko (což může zahrnovat skutečně náhodné hodnoty). I když sekvence, které jsou blíže skutečně náhodným, lze generovat pomocí hardwarové generátory náhodných čísel, pseudonáhodné generátory čísel jsou v praxi důležité pro jejich rychlost při generování čísel a jejich reprodukovatelnost.[2]
PRNG jsou ústřední v aplikacích, jako je simulace (např. pro Metoda Monte Carlo ), elektronické hry (např. pro procesní generování ), a kryptografie. Kryptografické aplikace vyžadují, aby výstup nebyl předvídatelný z dřívějších výstupů atd propracované algoritmy, které nezdědí linearitu jednodušších PRNG, jsou zapotřebí.
Dobré statistické vlastnosti jsou ústředním požadavkem na výstup PRNG. Obecně je nutná pečlivá matematická analýza, aby bylo jisté, že PRNG generuje čísla, která jsou dostatečně blízká náhodným, aby vyhovovala zamýšlenému použití. John von Neumann varoval před nesprávnou interpretací PRNG jako skutečně náhodného generátoru a vtipkoval, že „Každý, kdo uvažuje o aritmetických metodách vytváření náhodných číslic, je samozřejmě ve stavu hříchu.“[3]
Potenciální problémy s deterministickými generátory
V praxi se projevuje výstup z mnoha běžných PRNG artefakty které jim způsobí selhání statistických testů detekce vzorů. Tyto zahrnují:
- Kratší než očekávané období pro některé počáteční stavy (takové počáteční stavy lze v tomto kontextu nazvat „slabými“);
- Nedostatečná rovnoměrnost distribuce pro velká množství generovaných čísel;
- Korelace postupných hodnot;
- Špatné rozměrové rozdělení výstupní sekvence;
- Vzdálenosti mezi místy, kde se vyskytují určité hodnoty, jsou distribuovány odlišně od vzdáleností v náhodném pořadí sekvencí.
Vady vykazované chybnými PRNG se pohybují od nepozorovatelných (a neznámých) po velmi zjevné. Příkladem byl RANDU algoritmus náhodných čísel používaný po celá desetiletí sálové počítače. Byl vážně vadný, ale jeho nedostatečnost zůstávala po velmi dlouhou dobu nezjištěna.
V mnoha oblastech se výzkumné práce před 21. stoletím spoléhaly na náhodný výběr nebo na Monte Carlo simulace, nebo jinými způsoby založené na PRNG, byly mnohem méně spolehlivé než ideální v důsledku použití nekvalitních PRNG.[4] I dnes je někdy nutná opatrnost, jak dokládá následující varování v dokumentu Mezinárodní encyklopedie statistických věd (2010).[5]
Seznam široce používaných generátorů, které by měly být vyřazeny, je mnohem delší [než seznam dobrých generátorů]. Nevěřte slepě dodavatelům softwaru. Zkontrolujte výchozí RNG svého oblíbeného softwaru a buďte připraveni jej v případě potřeby vyměnit. Toto poslední doporučení bylo vydáváno znovu a znovu za posledních 40 let. Možná překvapivě zůstává dnes stejně relevantní jako před 40 lety.
Pro ilustraci zvažte běžně používaný programovací jazyk Jáva. Od roku 2017[Aktualizace], Java stále spoléhá na lineární shodný generátor (LCG) pro svůj PRNG,[6][7] které mají nízkou kvalitu - viz dále níže.
Jeden známý PRNG, který se vyhnul velkým problémům a přesto běžel poměrně rychle, byl Mersenne Twister (diskutováno níže), která byla zveřejněna v roce 1998. Další kvalitnější PRNG, a to jak z hlediska výpočetního, tak statistického výkonu, byly vyvinuty před a po tomto datu; tyto lze identifikovat v Seznam generátorů pseudonáhodných čísel.
Generátory založené na lineárních opakováních
Ve druhé polovině 20. století zahrnovala standardní třída algoritmů používaných pro PRNG lineární shodné generátory. Bylo známo, že kvalita LCG je nedostatečná, ale lepší metody nebyly k dispozici. Press et al. (2007) popsali výsledek takto: „Pokud by všechny vědecké práce, jejichž výsledky jsou kvůli [LCG a souvisejícím] pochybné, zmizely z police knihoven, na každé polici by byla mezera zhruba tak velká jako vaše pěst.“[8]
Významným pokrokem v konstrukci pseudonáhodných generátorů bylo zavedení technik založených na lineární rekurence na poli dvou prvků; takové generátory souvisí lineární zpětnovazební posuvné registry.
Vynález z roku 1997 Mersenne Twister,[9] zejména se vyhnul mnoha problémům s dřívějšími generátory. Mersenne Twister má období 219 937−1 iterace (≈4,3×106001), je prokázáno, že je ekvidistribuováno v (až) 623 dimenzích (pro 32bitové hodnoty) a v době jeho zavedení běžel rychleji než jiné statisticky přiměřené generátory.
V roce 2003 George Marsaglia představil rodinu xorshift generátory,[10] opět na základě lineárního opakování. Takové generátory jsou extrémně rychlé a v kombinaci s nelineární operací projdou silnými statistickými testy.[11][12][13]
V roce 2006 STUDNA byla vyvinuta rodina generátorů.[14] Generátory WELL v některých ohledech zlepšují kvalitu Mersenne Twister - který má příliš velký stavový prostor a velmi pomalé zotavení ze stavových prostorů s velkým počtem nul.
Kryptograficky bezpečné generátory pseudonáhodných čísel
PRNG vhodný pro kryptografické aplikace se nazývá a kryptograficky bezpečný PRNG (CSPRNG). Požadavek na CSPRNG je, že protivník, který nezná semeno, má pouze zanedbatelný výhoda při rozlišování výstupní sekvence generátoru od náhodné sekvence. Jinými slovy, zatímco PRNG je vyžadováno pouze k úspěšnému absolvování určitých statistických testů, CSPRNG musí projít všemi statistickými testy, které jsou omezeny na polynomiální čas ve velikosti semene. Ačkoli důkaz této vlastnosti přesahuje současný stav techniky teorie výpočetní složitosti, silný důkaz může poskytnout snižování CSPRNG na a problém to se předpokládá tvrdý, jako celočíselná faktorizace.[15] Obecně může být zapotřebí let přezkoumání, než bude možné algoritmus certifikovat jako CSPRNG.
Některé třídy CSPRNG zahrnují následující:
- proudové šifry
- blokové šifry běží dovnitř čelit[16] nebo výstupní zpětná vazba režimu
- PRNG, které byly navrženy speciálně tak, aby byly kryptograficky bezpečné, jako například Microsoft je Kryptografické programovací rozhraní aplikace funkce CryptGenRandom, Yarrowův algoritmus (začleněna do Mac OS X a FreeBSD ), a Fortuna
- kombinované PRNG, které se pokoušejí kombinovat několik primitivních algoritmů PRNG s cílem odstranit jakoukoli detekovatelnou nenáhodnost
- speciální návrhy založené na předpokladech matematické tvrdosti: příklady zahrnují Generátor Micali – Schnorr,[17] Naor-Reingoldova pseudonáhodná funkce a Blum Blum Shub algoritmus, který poskytuje silný bezpečnostní důkaz (takové algoritmy jsou ve srovnání s tradičními konstrukcemi poměrně pomalé a pro mnoho aplikací nepraktické)
- generické PRNG: i když se ukázalo, že (kryptograficky) zabezpečený PRNG lze generovat obecně z jakéhokoli jednosměrná funkce,[18] tato generická konstrukce je v praxi extrémně pomalá, takže je hlavně teoretického zájmu.
Ukázalo se, že je pravděpodobné, že NSA vložil asymetrický zadní dveře do NIST certifikovaný generátor náhodných čísel Dual_EC_DRBG.[19]
Většina algoritmů PRNG produkuje sekvence, které jsou rovnoměrně rozloženo některým z několika testů. Je to otevřená otázka a jedna z ústředních bodů teorie a praxe kryptografie, zda existuje způsob, jak odlišit výstup vysoce kvalitního PRNG od skutečně náhodné sekvence. V tomto nastavení rozlišovač ví, že byl použit buď známý algoritmus PRNG (ale ne stát, s nímž byl inicializován), nebo byl použit skutečně náhodný algoritmus, a musí mezi nimi rozlišovat.[20] Zabezpečení většiny kryptografických algoritmů a protokolů využívajících PRNG je založeno na předpokladu, že je nemožné odlišit použití vhodného PRNG od použití skutečně náhodné sekvence. Nejjednodušší příklady této závislosti jsou proudové šifry, které (nejčastěji) fungují exkluzivní nebo -ing prostý text zprávy s výstupem PRNG, produkující šifrový text. Návrh kryptograficky vhodných PRNG je extrémně obtížný, protože musí splňovat další kritéria. Velikost jeho období je důležitým faktorem v kryptografické vhodnosti PRNG, ale není jediným.
Kritéria hodnocení BSI
Němec Federální úřad pro informační bezpečnost (Bundesamt für Sicherheit in der Informationstechnik, BSI) stanovila čtyři kritéria kvality deterministických generátorů náhodných čísel.[21] Jsou shrnuty zde:
- K1 - Měla by existovat vysoká pravděpodobnost, že generované sekvence náhodných čísel se navzájem liší.
- K2 - Pořadí čísel je podle specifikovaných statistických testů nerozeznatelné od „skutečně náhodných“ čísel. Testy jsou monobit test (stejný počet jednotek a nul v pořadí), poker test (speciální instance chí-kvadrát test ), běží test (počítá frekvenci běhů různých délek), longruns test (zkontroluje, zda v 20 000 bitech sekvence existuje nějaký běh délky 34 nebo větší) - oba od BSI[21] a NIST,[22] a autokorelace test. V podstatě jsou tyto požadavky testem toho, jak dobře bitová sekvence: má nuly a ty stejně často; po posloupnosti n nuly (nebo jedničky), další bit jedna (nebo nula) s pravděpodobností polovina; a jakákoli vybraná subsekvence neobsahuje žádné informace o dalších prvcích v sekvenci.
- K3 - Mělo by být nemožné, aby útočník (pro všechny praktické účely) vypočítal nebo jinak odhadl z jakékoli dané subsekvence, jakékoli předchozí nebo budoucí hodnoty v sekvenci, ani žádný vnitřní stav generátoru.
- K4 - Pro všechny praktické účely by mělo být nemožné, aby útočník vypočítal nebo uhádl z vnitřního stavu generátoru všechna předchozí čísla v pořadí nebo jakékoli předchozí stavy vnitřního generátoru.
U kryptografických aplikací jsou přijatelné pouze generátory splňující standardy K3 nebo K4.
Matematická definice
Dáno
- - rozdělení pravděpodobnosti na (kde je standard Sada Borel na skutečné lince)
- - neprázdná kolekce sad Borel , např. . Li není specifikováno, může to být buď nebo , v závislosti na kontextu.
- - neprázdná sada (nemusí to být nutně sada Borel). Často je množina mezi je Podpěra, podpora a jeho interiér; například pokud je rovnoměrné rozdělení na intervalu , možná . Li není specifikováno, předpokládá se, že jde o nějakou sadu obsaženou v podpoře a obsahující jeho vnitřek, v závislosti na kontextu.
Říkáme funkci (kde je množina kladných celých čísel) a generátor pseudonáhodných čísel pro daný přijímání hodnot v kdyby a jen kdyby
( označuje počet prvků v konečné sadě .)
Je možné ukázat, že pokud je generátor pseudonáhodných čísel pro rovnoměrné rozdělení a pokud je CDF některého daného rozdělení pravděpodobnosti , pak je generátor pseudonáhodných čísel pro , kde je percentil z , tj. . Intuitivně lze libovolné rozdělení simulovat ze simulace standardního rovnoměrného rozdělení.
Rané přístupy
Časný počítačový PRNG, navrhl John von Neumann v roce 1946, je známý jako metoda středního čtverce. Algoritmus je následující: vezměte libovolné číslo, zarovnejte ho, odstraňte prostřední číslice výsledného čísla jako „náhodné číslo“ a poté toto číslo použijte jako základ pro další iteraci. Například kvadraturou čísla „1111“ se získá „1234321“, kterou lze zapsat jako „01234321“, přičemž 8místné číslo je druhou mocninou čtyřmístného čísla. To dává „2343“ jako „náhodné“ číslo. Opakováním tohoto postupu získáte jako další výsledek „4896“ atd. Von Neumann použil desetimístná čísla, ale postup byl stejný.
Problém metody „prostřední čtverec“ spočívá v tom, že se všechny sekvence nakonec opakují, některé velmi rychle, například „0000“. Von Neumann si toho byl vědom, ale shledal přístup dostatečný pro jeho účely a obával se, že matematické „opravy“ chyby jednoduše skryjí, místo aby je odstranily.
Von Neumann považoval hardwarové generátory náhodných čísel za nevhodné, protože pokud nezaznamenají vygenerovaný výstup, nemohou být později testovány na chyby. Pokud by zaznamenali svůj výstup, vyčerpali by omezené paměti počítače, které byly tehdy k dispozici, a tedy schopnost počítače číst a psát čísla. Pokud by byla čísla zapisována na karty, psaní a čtení by trvalo mnohem déle. Na ENIAC počítač, který používal, generovala metoda „prostředního čtverce“ čísla stokrát rychlejší než čtení čísel z děrné štítky.
Metodu středního čtverce od té doby nahradily propracovanější generátory.
Poslední novinkou je kombinace prostředního čtverce s a Weylova sekvence. Tato metoda produkuje vysoce kvalitní výstup po dlouhou dobu (viz Middle Square Weyl Sequence PRNG ).
Nejednotné generátory
Čísla vybraná z nejednotného rozdělení pravděpodobnosti lze generovat pomocí a rovnoměrné rozdělení PRNG a funkce, která spojuje dvě distribuce.
Nejprve je třeba kumulativní distribuční funkce cílové distribuce :
Všimněte si, že . Použití náhodného čísla C dostaneme z jednotného rozdělení jako hustoty pravděpodobnosti na „projít“
aby
je číslo náhodně vybrané z distribuce .
Například inverzní kumulativní Gaussovo rozdělení s ideální jednotnou PRNG s rozsahem (0, 1) jako vstup by vyprodukoval posloupnost (pouze kladných) hodnot s Gaussovým rozdělením; nicméně
- Při použití praktických reprezentací čísel musí být nekonečné "konce" distribuce zkráceny na konečné hodnoty.
- Opakovaný přepočet by měly být sníženy prostředky, jako je zikkuratový algoritmus pro rychlejší generaci.
Podobné úvahy platí i pro generování jiných nejednotných distribucí, jako je Rayleigh a jed.
Viz také
- Seznam generátorů pseudonáhodných čísel
- Aplikace náhodnosti
- Sekvence s nízkou odchylkou
- Pseudonáhodná binární sekvence
- Pseudonáhodný šum
- Generování náhodných čísel
- Útok generátoru náhodných čísel
- Náhodnost
- Statistická náhodnost
Reference
- ^ Barker, Elaine; Barker, William; Burr, William; Polk, William; Smid, Miles (červenec 2012). „Doporučení pro správu klíčů“ (PDF). NIST Zvláštní publikace 800-57. NIST. Citováno 19. srpna 2013.
- ^ "Generátory pseudonáhodných čísel". Khan Academy. Citováno 2016-01-11.
- ^ Von Neumann, John (1951). "Různé techniky používané v souvislosti s náhodnými číslicemi" (PDF). Série Národního úřadu pro aplikovanou matematiku. 12: 36–38.
- ^ Press et al. (2007), kap
- ^ L'Ecuyer, Pierre (2010). Msgstr "Jednotné generátory náhodných čísel". V Lovric, Miodrag (ed.). Mezinárodní encyklopedie statistických věd. Springer. p. 1629. ISBN 3-642-04897-8.
- ^ Náhodné (Java Platform SE 8) Dokumentace Java Platform Standard Edition 8.
- ^ Random.java na OpenJDK.
- ^ Press et al. (2007) §7.1
- ^ Matsumoto, Makoto; Nishimura, Takuji (1998). „Mersenne twister: 623-dimenzionálně ekvidistribuovaný uniformní generátor pseudonáhodných čísel“ (PDF). Transakce ACM na modelování a počítačové simulaci. ACM. 8 (1): 3–30. doi:10.1145/272991.272995.
- ^ Marsaglia, George (červenec 2003). „Xorshift RNG“. Žurnál statistického softwaru. 8 (14).
- ^ S.Vigna. „generátory xorshift * / xorshift + a přestřelka PRNG“.
- ^ Vigna S. (2016), „Experimentální průzkum generátorů xorshift Marsaglia“, Transakce ACM na matematickém softwaru, 42; doi:10.1145/2845077.
- ^ Vigna S. (2017), „Další kódování generátorů xorshift společnosti Marsaglia“, Journal of Computational and Applied Mathematics, 315; doi:10.1016 / j.cam.2016.11.006.
- ^ Panneton, François; L'Ecuyer, Pierre; Matsumoto, Makoto (2006). "Vylepšené generátory s dlouhou periodou založené na lineárních opakováních modulo 2" (PDF). Transakce ACM na matematickém softwaru. 32 (1): 1–16. doi:10.1145/1132973.1132974.
- ^ Píseň Y. Yan. Kryptanalytické útoky na RSA. Springer, 2007. str. 73. ISBN 978-0-387-48741-0.
- ^ Niels Ferguson, Bruce Schneier, Tadayoshi Kohno (2010). „Kryptografické inženýrství: Principy návrhu a praktické aplikace, Kapitola 9.4: Generátor“ (PDF).CS1 maint: více jmen: seznam autorů (odkaz)
- ^ Klaus Pommerening (2016). "IV.4 Perfektní náhodné generátory". Kryptologie. uni-mainz.de. Citováno 2017-11-12.
Generátor MICALI-SCHNORR
- ^ Pass, Rafaeli. „Lecture 11: The Goldreich-Levin theorem“ (PDF). COM S 687 Úvod do kryptografie. Citováno 20. července 2016.
- ^ Matthew Green. "Mnoho nedostatků Dual_EC_DRBG".
- ^ Katz, Jonathan; Yehuda, Lindell (2014). Úvod do moderní kryptografie. CRC tisk. p. 70.
- ^ A b Schindler, Werner (2. prosince 1999). „Třídy funkčnosti a metodika hodnocení pro deterministické generátory náhodných čísel“ (PDF). Anwendungshinweise und Interpretationen (AIS). Bundesamt für Sicherheit in der Informationstechnik. s. 5–11. Citováno 19. srpna 2013.
- ^ „Bezpečnostní požadavky na kryptografické moduly“. FIPS. NIST. 11.01.1994. p. 4.11.1 Testy při zapnutí. Archivovány od originál 27. května 2013. Citováno 19. srpna 2013.
Bibliografie
- Barker E., Kelsey J., Doporučení pro generování náhodných čísel pomocí deterministických generátorů náhodných bitů, NIST SP800-90A, leden 2012
- Brent R.P., "Některé generátory náhodných čísel s dlouhou periodou využívající posuny a xory", ANZIAM Journal, 2007; 48: C188 – C202
- Gentle J.E. (2003), Generování náhodných čísel a metody Monte CarloSpringer.
- Hörmann W., Leydold J., Derflinger G. (2004, 2011), Automatické nerovnoměrné generování náhodných variací, Springer-Verlag.
- Knuth D.E.. Umění počítačového programování, Díl 2: Seminumerické algoritmy, Třetí edice. Addison-Wesley, 1997. ISBN 0-201-89684-2. Kapitola 3. [Rozsáhlé pokrytí statistických testů na nenáhodnost.]
- Luby M., Pseudonáhodnost a kryptografické aplikace, Princeton Univ Press, 1996. ISBN 9780691025469
- von Neumann J., „Různé techniky používané v souvislosti s náhodnými číslicemi,“ v A.S. Householder, G.E. Forsythe a H.H. Germond, eds., Metoda Monte Carlo„National Bureau of Standards Applied Mathematics Series, 12 (Washington, D.C .: U.S. Government Printing Office, 1951): 36–38.
- Peterson, Ivars (1997). Džungle náhodnosti: matematické safari. New York: John Wiley & Sons. ISBN 0-471-16449-6.
- Press W.H., Teukolsky S.A., Vetterling W.T., Flannery B.P. (2007), Numerické recepty (Cambridge University Press ).
- Viega J., "Praktické generování náhodných čísel v softwaru ", Proc. 19. výroční konference aplikací pro zabezpečení počítačů, prosinec 2003.
externí odkazy
- TestU01: Zdarma, nejmodernější (GPL ) C ++ Sada pro testování náhodných čísel.
- DieHarder: Zdarma (GPL ) C Sada pro testování náhodných čísel.
- "Generování náhodných čísel " (v vestavěné systémy ) od Erica Unera (2004)
- "Analýza generátoru náhodných čísel v systému Linux „od Zvi Guttermana, Benny Pinkas a Tzachy Reinman (2006)
- "Lepší generátory pseudonáhod „Parikshit Gopalan, Raghu Meka, Omer Reingold, Luca Trevisan, a Salil Vadhan (Microsoft Research, 2012)
- rand () Považováno za škodlivé na Youtube autor: Stephan Lavavej (Microsoft, 2013)
- Wsphynx jednoduchý online generátor náhodných čísel. Náhodná čísla jsou generována algoritmy Javascript pseudonandom number generators (PRNGs)