Algoritmus Berlekamp – Rabin - Berlekamp–Rabin algorithm

v teorie čísel, Berlekampův algoritmus pro hledání kořenů, také nazývaný Algoritmus Berlekamp – Rabin, je pravděpodobnostní metoda hledání kořenů z polynomy přes pole . Metodu objevil Elwyn Berlekamp v roce 1970[1] jako pomocník k algoritmus pro polynomiální faktorizaci nad konečnými poli. Algoritmus byl později upraven uživatelem Rabine pro libovolná konečná pole v roce 1979.[2] Metoda byla také nezávisle objevena před Berlekampem jinými vědci.[3]

Dějiny

Metodu navrhl Elwyn Berlekamp ve své práci z roku 1970[1] na polynomiální faktorizaci nad konečnými poli. Jeho původní práce postrádala formální podobu správnost důkaz[2] a později byl vylepšen a upraven pro libovolná konečná pole Michael Rabin.[2] V roce 1986 navrhl René Peralta podobný algoritmus[4] pro hledání odmocniny v .[5] V roce 2000 byla Peralta metoda zobecněna pro kubické rovnice.[6]

Prohlášení o problému

Nechat být liché prvočíslo. Zvažte polynom přes pole zbytků modulo . Algoritmus by měl najít všechny v takhle v .[2][7]

Algoritmus

Randomizace

Nechat . Nalezení všech kořenů tohoto polynomu je ekvivalentní nalezení jeho faktorizace na lineární faktory. K nalezení takovéto faktorizace stačí rozdělit polynom na dva netriviální dělitele a rekurzivně je rozčlenit. Chcete-li to provést, zvažte polynom kde je nějaký libovolný prvek . Pokud lze tento polynom představovat jako součin pak z hlediska počátečního polynomu to znamená , který poskytuje potřebnou faktorizaci .[1][7]

Klasifikace elementy

Kvůli Eulerovo kritérium, pro každého monomiální přesně jedna z následujících vlastností platí:[1]

  1. Monomiál se rovná -li ,
  2. Monomiální dělí -li je kvadratický zbytek modulo ,
  3. Monomiální dělí -li je kvadratické nereziduální modulo .

Tedy pokud není dělitelné , které lze poté zkontrolovat samostatně se rovná součinu produktu největší společní dělitelé a .[7]

Berlekampova metoda

Výše uvedená vlastnost vede k následujícímu algoritmu:[1]

  1. Explicitně vypočítat koeficienty ,
  2. Vypočítejte zbývající částku modulo čtvercem aktuálního polynomu a převzetím zbytku modulo ,
  3. Použitím umocňování druhou mocninou a polynomy vypočtené v předchozích krocích vypočítají zbytek modulo ,
  4. Li pak výše uvedené poskytují netriviální faktorizaci ,
  5. Jinak všechny kořeny jsou buď zbytky nebo ne-zbytky současně a je třeba zvolit jiný .

Li je dělitelné některými nelineárními primitivní polynom přes pak při výpočtu s a získá se netriviální faktorizace , tedy algoritmus umožňuje najít všechny kořeny libovolných polynomů .

Modulární druhá odmocnina

Zvažte rovnici mající prvky a jako jeho kořeny. Řešení této rovnice je ekvivalentní faktorizaci polynomu přes . V tomto konkrétním případě stačí pouze vypočítat . Pro tento polynom bude platit přesně jedna z následujících vlastností:

  1. GCD se rovná což znamená, že a jsou oba kvadratické nezbytky,
  2. GCD se rovná což znamená, že obě čísla jsou kvadratické zbytky,
  3. GCD se rovná což znamená, že právě jedno z těchto čísel je kvadratický zbytek.

Ve třetím případě se GCD rovná jedné nebo . Umožňuje napsat řešení jako .[1]

Příklad

Předpokládejme, že musíme vyřešit rovnici . K tomu je třeba faktorizovat . Zvažte několik možných hodnot :

  1. Nechat . Pak , tím pádem . Obě čísla jsou kvadratické nezbytky, takže musíme vzít nějaké další .
  1. Nechat . Pak , tím pádem . Z toho vyplývá , tak a .

Ruční kontrola ukazuje, že ve skutečnosti a .

Důkaz správnosti

Algoritmus najde faktorizaci ve všech případech kromě těch, kdy jsou všechna čísla jsou kvadratické zbytky nebo ne-zbytky současně. Podle teorie cyklotomie,[8] pravděpodobnost takové události pro případ, kdy jsou všechny zbytky nebo ne-zbytky současně (tj. když by selhal) lze odhadnout jako kde je počet různých hodnot v .[1] Tímto způsobem i pro nejhorší případ a , lze pravděpodobnost chyby odhadnout na a pro modulární odmocninu je pravděpodobnost chyby případu maximálně .

Složitost

Nechť má polynom stupeň . Složitost algoritmu odvodíme takto:

  1. V důsledku binomická věta , můžeme přejít z na v čas.
  2. Polynomické násobení a převzetí zbytku jednoho polynomiálního modulu lze provést v , tedy výpočet se provádí v .
  3. Binární umocňování funguje v .
  4. Užívání dvou polynomů pomocí Euklidovský algoritmus pracuje v .

Celý postup tak může být proveden v . Za použití rychlá Fourierova transformace a algoritmus Half-GCD,[9] složitost algoritmu může být vylepšena . Pro případ modulární odmocniny je stupeň , tedy celá složitost algoritmu je v takovém případě omezena na iteraci.[7]

Reference

  1. ^ A b C d E F G Berlekamp, ​​E. R. (1970). "Faktorování polynomů přes velká konečná pole". Matematika výpočtu. 24 (111): 713–735. doi:10.1090 / S0025-5718-1970-0276200-X. ISSN  0025-5718.
  2. ^ A b C d M. Rabin (1980). "Pravděpodobnostní algoritmy v konečných polích". SIAM Journal on Computing. 9 (2): 273–280. doi:10.1137/0209024. ISSN  0097-5397.
  3. ^ Donald E. Knuth (1998). Umění počítačového programování. Sv. 2 sv. 2. ISBN  978-0201896848. OCLC  900627019.
  4. ^ Tsz-Wo Sze (2011). "Na převzetí odmocniny bez kvadratických zbytků nad konečnými poli". Matematika výpočtu. 80 (275): 1797–1811. arXiv:0812.2591. doi:10.1090 / s0025-5718-2011-02419-1. ISSN  0025-5718.
  5. ^ R. Peralta (listopad 1986). Msgstr "Jednoduchý a rychlý pravděpodobnostní algoritmus pro výpočet druhé odmocniny modulo prvočíslo (Corresp.)". Transakce IEEE na teorii informací. 32 (6): 846–847. doi:10.1109 / TIT.1986.1057236. ISSN  0018-9448.
  6. ^ C Padró, G Sáez (srpen 2002). "Získání kořenů kostky v Zm". Aplikovaná matematická písmena. 15 (6): 703–708. doi:10.1016 / s0893-9659 (02) 00031-9. ISSN  0893-9659.
  7. ^ A b C d Alfred J. Menezes, Ian F. Blake, XuHong Gao, Ronald C. Mullin, Scott A. Vanstone (1993). Aplikace konečných polí. Springer International Series in Engineering and Computer Science. Springer USA. ISBN  9780792392828.CS1 maint: více jmen: seznam autorů (odkaz)
  8. ^ Marshall Hall (1998). Kombinatorická teorie. John Wiley & Sons. ISBN  9780471315186.
  9. ^ Aho, Alfred V. (1974). Návrh a analýza počítačových algoritmů. Addison-Wesley Pub. Co. ISBN  0201000296.