Algoritma Berlekamp–Rabin

Dari Wikipedia bahasa Indonesia, ensiklopedia bebas
Foto Algoritma Berlekamp–Rabin

Dalam teori bilangan, algoritma Berlekamp–Rabin adalah metode probabilistik pencarian akar dari polinomial pada medan . Metode ini ditemukan oleh Elwyn Berlekamp pada tahun 1970[1] sebagai tambahan algoritma untuk faktorisasi polinomial pada medan berhingga. Algoritma kemudian dimodifikasi oleh Rabin untuk medan berhingga sebarang pada tahun 1979.[2] Sebelum Berlekamp, metode ini juga ditemukan secara terpisah oleh peneliti lain.[3]

Sejarah[sunting | sunting sumber]

Metode ini diusulkan oleh Elwyn Berlekamp dalam karyanya tahun 1970[1] tentang faktorisasi polinomial pada medan berhingga. Karya aslinya tidak memiliki bukti kebenaran formal[2] dan kemudian disempurnakan dan dimodifikasi untuk medan berhingga sebarang oleh Michael Rabin.[2] Pada tahun 1986, René Peralta mengusulkan algoritma serupa[4] untuk mencari akar kuadrat .[5] Perumuman metode Peralita untuk persamaan kubik dibuat pada tahun 2000.[6]

Pernyataan masalah[sunting | sunting sumber]

Misalkan adalah bilangan prima ganjil, dan misalkan pula polinomial atas medan dari modulo sisa . Tujuan pernyataan masalah ini adalah bahwa algoritma Berlekamp harus menemukan semua di sehingga di .[2][7]

Algoritma[sunting | sunting sumber]

Pengacakan[sunting | sunting sumber]

Misalkan . Menemukan semua akar polinomial ini sama saja dengan mencari faktorisasinya menjadi faktor linear. Untuk menemukan faktorisasi tersebut, cukup membagi polinomial menjadi dua pembagi non-trivial dan memfaktorkannya secara rekursif. Lebih lanjut, misalkan polinomial , untuk setiap anggota . Jika polinomial tersebut dinyatakan sebagai hasilkali , maka dalam bentuk polinomial awal, mengartikan bahwa . Fungsi yang merupakan menyediakan faktorisasi dibutuhkan dari .[1][7]

Klasifikasi elemen [sunting | sunting sumber]

Menurut kriteria Euler, untuk setiap monomial , berlaku tepat salah satu dari sifat-sifat berikut:[1]

  1. Monomial sama dengan jika ,
  2. Pembagian monomial jika adalah residu kuadrat modulo ,
  3. Pembagian monomial jika adalah non-residul kuadrat modulo .

Jadi, jika tidak habis dibagi , yang dapat diperiksa secara terpisah, maka sama dengan hasilkali dari faktor persekutuan terbesar dan .[7]

Metode Berlekamp[sunting | sunting sumber]

Sifat-sifat di atas mengarah pada algoritma berikut:[1]

  1. Hitung secara eksplisit koefisien ,
  2. Hitung sisa modulo dengan mengkuadratkan polinomial dan mengambil sisa modulo ,
  3. Menggunakan eksponensiasi yang dikuadratkan dan polinomial yang dihitung pada langkah sebelumnya, hitung sisa modulo ,
  4. Jika , maka yang disebutkan diatas memberikan faktorisasi non-trivial dari ,
  5. Jika tidak, maka semua akar adalah residu atau non-residu secara bersamaan dan harus memilih yang lain.

Jika habis dibagi oleh setiap polinomial primitif atas maka saat menghitung dengan dan akan diperoleh faktorisasi non-trivial dari , sehingga algoritma memungkinkan untuk menemukan semua akar polinomial sebarang atas .

Akar kuadrat modular[sunting | sunting sumber]

Misalkan persamaan mempunyai anggota dan sebagai akarnya. Solusi persamaan ini ekuivalen dengan faktorisasi polinomial atas . Dalam masalah kasus istimewa ini, cukup hitung saja. Untuk polinomial tersebut, ada tepat satu dari sifat-sifat yang berlaku sebagai berikut:

  1. FPB sama dengan , yang berarti bahwa dan merupakan non-residu kuadratik,
  2. FPB sama dengan , yang berarti kedua bilangan tersebut merupakan residu kuadratik,
  3. FPB sama dengan , yang berarti tepat salah satu dari bilangan tersebut merupakan residu kuadrat.

Pada kasus ketiga, FPB sama dengan atau . Hal ini memungkinkan untuk menulis solusi sebagai .[1]

Contoh[sunting | sunting sumber]

Asumsi bahwa persamaan dapat diselesaikan. Caranya adalah dengan memfaktorkan . Nilai dapat dibagi menjadi beberapa kasus dengan memisalkannya sebagai berikut:

  1. Misalkan , maka . Jadi, . Karena bilangan merupakan non-residu kuadrat, maka perlu dicari nilai lain.
  2. Misalkan , maka . Jadi, . Karena , maka dan .

Hasil pemeriksaan yang dilakukan secara manual memperlihatkan bahwa dan .

Bukti kebenaran[sunting | sunting sumber]

Algoritma menemukan faktorisasi dalam semua kasus, kecuali ketika semua bilangan adalah residu kuadrat atau non-residu secara bersamaan. Menurut teori siklotomi,[8] peluang kejadiannya untuk kasus ketika juga merupakan semua residu atau non-residu secara bersamaan (yaitu, ketika tidak berhasil) diestimasi sebagai , untuk adalah jumlah nilai yang berbeda dalam .[1] Dengan cara ini, bahkan untuk kasus galat dan , maka estimasi peluang galatnya adalah , dan untuk kasus akar kuadrat modular, probabilitas galat setidaknya bernilai .

Kompleksitas[sunting | sunting sumber]

Misalkan suatu polinomial merupakan polinomial berderajat , maka kompleksitas algoritma dapat diturunkan sebagai berikut:

  1. Karena menurut teorema binomial mengatakan bahwa , maka dapat dilakukan transisi dari ke dalam waktu .
  2. Perkalian polinomial dan mengambil sisa dari satu polinomial yang modulo dengan yang lain dapat dilakukan di . Jadi, perhitungan dilakukan di .
  3. Eksponensial biner bekerja di .
  4. Mengambil dari dua polinomial melalui algoritma Euklides yang bekerja di .

Jadi, seluruh prosedur dapat dilakukan di . Dengan menggunakan transformasi Fourier cepat dan algoritma setengah-FPB,[9] maka kompleksitas algoritmanya dapat ditingkatkan menjadi . Untuk kasus akar kuadrat modular, derajatnya adalah , sehingga seluruh kompleksitas algoritma dalam kasus tersebut dibatasi dengan per iterasi.[7]

Referensi[sunting | sunting sumber]

  1. ^ a b c d e f g Berlekamp, E. R. (1970). "Factoring polynomials over large finite fields". Mathematics of Computation (dalam bahasa Inggris). 24 (111): 713–735. doi:10.1090/S0025-5718-1970-0276200-Xalt=Dapat diakses gratis. ISSN 0025-5718. 
  2. ^ a b c d M. Rabin (1980). "Probabilistic Algorithms in Finite Fields". SIAM Journal on Computing. 9 (2): 273–280. doi:10.1137/0209024. ISSN 0097-5397. 
  3. ^ Donald E Knuth (1998). The art of computer programming. Vol. 2 Vol. 2. ISBN 978-0201896848. OCLC 900627019. 
  4. ^ Tsz-Wo Sze (2011). "On taking square roots without quadratic nonresidues over finite fields". Mathematics of Computation. 80 (275): 1797–1811. arXiv:0812.2591alt=Dapat diakses gratis. doi:10.1090/s0025-5718-2011-02419-1. ISSN 0025-5718. 
  5. ^ R. Peralta (November 1986). "A simple and fast probabilistic algorithm for computing square roots modulo a prime number (Corresp.)". IEEE Transactions on Information Theory. 32 (6): 846–847. doi:10.1109/TIT.1986.1057236. ISSN 0018-9448. 
  6. ^ C Padró, G Sáez (August 2002). "Taking cube roots in Zm". Applied Mathematics Letters. 15 (6): 703–708. doi:10.1016/s0893-9659(02)00031-9alt=Dapat diakses gratis. ISSN 0893-9659. 
  7. ^ a b c d Alfred J. Menezes, Ian F. Blake, XuHong Gao, Ronald C. Mullin, Scott A. Vanstone (1993). Applications of Finite Fields. The Springer International Series in Engineering and Computer Science. Springer US. ISBN 9780792392828. 
  8. ^ Marshall Hall (1998). Combinatorial Theory. John Wiley & Sons. ISBN 9780471315186. 
  9. ^ Aho, Alfred V. (1974). The design and analysis of computer algorithmsPerlu mendaftar (gratis). Addison-Wesley Pub. Co. ISBN 0201000296. 

Templat:Algoritma teori bilangan