AKS primality test

The AKS primality test (also known as Agrawal–Kayal–Saxena primality test and cyclotomic AKS test) is a deterministic primality-proving algorithm created and published by Manindra Agrawal, Neeraj Kayal, and Nitin Saxena, computer scientists at the Indian Institute of Technology Kanpur, on August 6, 2002, in an article titled "PRIMES is in P".[1] The algorithm was the first one which is able to determine in polynomial time, whether a given number is prime or composite without relying on mathematical conjectures such as the generalized Riemann hypothesis. The proof is also notable for not relying on the field of analysis.[2] In 2006 the authors received both the Gödel Prize and Fulkerson Prize for their work.

Importance

AKS is the first primality-proving algorithm to be simultaneously general, polynomial-time, deterministic, and unconditionally correct. Previous algorithms had been developed for centuries and achieved three of these properties at most, but not all four.

  • The AKS algorithm can be used to verify the primality of any general number given. Many fast primality tests are known that work only for numbers with certain properties. For example, the Lucas–Lehmer test works only for Mersenne numbers, while Pépin's test can be applied to Fermat numbers only.
  • The maximum running time of the algorithm can be bounded by a polynomial over the number of digits in the target number. ECPP and APR conclusively prove or disprove that a given number is prime, but are not known to have polynomial time bounds for all inputs.
  • The algorithm is guaranteed to distinguish deterministically whether the target number is prime or composite. Randomized tests, such as Miller–Rabin and Baillie–PSW, can test any given number for primality in polynomial time, but are known to produce only a probabilistic result.
  • The correctness of AKS is not conditional on any subsidiary unproven hypothesis. In contrast, Miller's version of the Miller–Rabin test is fully deterministic and runs in polynomial time over all inputs, but its correctness depends on the truth of the yet-unproven generalized Riemann hypothesis.

While the algorithm is of immense theoretical importance, it is not used in practice, rendering it a galactic algorithm. For 64-bit inputs, the Baillie–PSW test is deterministic and runs many orders of magnitude faster. For larger inputs, the performance of the (also unconditionally correct) ECPP and APR tests is far superior to AKS. Additionally, ECPP can output a primality certificate that allows independent and rapid verification of the results, which is not possible with the AKS algorithm.

Concepts

The AKS primality test is based upon the following theorem: Given an integer and integer coprime to , is prime if and only if the polynomial congruence relation

holds within the polynomial ring .[1] Note that denotes the indeterminate which generates this polynomial ring.

This theorem is a generalization to polynomials of Fermat's little theorem. In one direction it can easily be proven using the binomial theorem together with the following property of the binomial coefficient:

for all if is prime.

While the relation (1) constitutes a primality test in itself, verifying it takes exponential time: the brute force approach would require the expansion of the polynomial and a reduction of the resulting coefficients.

The congruence is an equality in the polynomial ring . Evaluating in a quotient ring of creates an upper bound for the degree of the polynomials involved. The AKS evaluates the equality in , making the computational complexity dependent on the size of . For clarity,[1] this is expressed as the congruence

which is the same as:

for some polynomials and .

Note that all primes satisfy this relation (choosing in (3) gives (1), which holds for prime). This congruence can be checked in polynomial time when is polynomial to the digits of . The AKS algorithm evaluates this congruence for a large set of values, whose size is polynomial to the digits of . The proof of validity of the AKS algorithm shows that one can find an and a set of values with the above properties such that if the congruences hold then is a power of a prime.[1]

History and running time

In the first version of the above-cited paper, the authors proved the asymptotic time complexity of the algorithm to be (using Õ from big O notation)—the twelfth power of the number of digits in n times a factor that is polylogarithmic in the number of digits. However, this upper bound was rather loose; a widely-held conjecture about the distribution of the Sophie Germain primes would, if true, immediately cut the worst case down to .

In the months following the discovery, new variants appeared (Lenstra 2002, Pomerance 2002, Berrizbeitia 2002, Cheng 2003, Bernstein 2003a/b, Lenstra and Pomerance 2003), which improved the speed of computation greatly. Owing to the existence of the many variants, Crandall and Papadopoulos refer to the "AKS-class" of algorithms in their scientific paper "On the implementation of AKS-class primality tests", published in March 2003.

In response to some of these variants, and to other feedback, the paper "PRIMES is in P" was updated with a new formulation of the AKS algorithm and of its proof of correctness. (This version was eventually published in Annals of Mathematics.) While the basic idea remained the same, r was chosen in a new manner, and the proof of correctness was more coherently organized. The new proof relied almost exclusively on the behavior of cyclotomic polynomials over finite fields. The new upper bound on time complexity was , later reduced using additional results from sieve theory to .

In 2005, Pomerance and Lenstra demonstrated a variant of AKS that runs in operations,[3] leading to another updated version of the paper.[4] Agrawal, Kayal and Saxena proposed a variant which would run in if Agrawal's conjecture were true; however, a heuristic argument by Pomerance and Lenstra suggested that it is probably false.

The algorithm

The algorithm is as follows:[1]

Input: integer n > 1.
  1. Check if n is a perfect power: if n = ab for integers a > 1 and b > 1, then output composite.
  2. Find the smallest r such that ordr(n) > (log2 n)2. If r and n are not coprime, then output composite.
  3. For all 2 ≤ a ≤ min (r, n−1), check that a does not divide n: If a|n for some 2 ≤ a ≤ min (r, n−1), then output composite.
  4. If nr, then output prime.
  5. For a = 1 to do
    if (X+a)nXn+a (mod Xr − 1,n), then output composite;
  6. Output prime.

Here ordr(n) is the multiplicative order of n modulo r, log2 is the binary logarithm, and is Euler's totient function of r.

Step 3 is shown in the paper as checking 1 < gcd(a,n) < n for all ar. It can be seen this is equivalent to trial division up to r, which can be done very efficiently without using gcd. Similarly the comparison in step 4 can be replaced by having the trial division return prime once it has checked all values up to and including

Once beyond very small inputs, step 5 dominates the time taken. The essential reduction in complexity (from exponential to polynomial) is achieved by performing all calculations in the finite ring

consisting of elements. This ring contains only the monomials , and the coefficients are in which has elements, all of them codable within bits.

Most later improvements made to the algorithm have concentrated on reducing the size of r, which makes the core operation in step 5 faster, and in reducing the size of s, the number of loops performed in step 5.[5] Typically these changes do not change the computational complexity, but can lead to many orders of magnitude less time taken; for example, Bernstein's final version has a theoretical speedup by a factor of over 2 million.

Proof of validity outline

For the algorithm to be correct, all steps that identify n must be correct. Steps 1, 3, and 4 are trivially correct, since they are based on direct tests of the divisibility of n. Step 5 is also correct: since (2) is true for any choice of a coprime to n and r if n is prime, an inequality means that n must be composite.

The difficult part of the proof is showing that step 6 is true. Its proof of correctness is based on the upper and lower bounds of a multiplicative group in constructed from the (X + a) binomials that are tested in step 5. Step 4 guarantees that these binomials are distinct elements of . For the particular choice of r, the bounds produce a contradiction unless n is prime or a power of a prime. Together with the test of step 1, this implies that n is always prime at step 6.[1]

Example 1: n = 31 is prime

   Input: integer n = 31 > 1.

   (* Step 1 *)
   If (n = ab for integers a > 1 and b > 1), 
     output composite.
     For ( b = 2; b <= log2(n); b++) {
       a = n1/b;
       If (a is integer), 
         Return[Composite]
     }
     a = n1/2...n1/4 = {5.568, 3.141, 2.360}

   (* Step 2 *)
   Find the smallest r such that Or(n) > (log2 n)2.
     maxk = ⌊(log2 n)2⌋;
     maxr = Max[3, ⌈(Log2 n)5⌉]; (* maxr really isn't needed *)
     nextR = True;
     For (r = 2; nextR && r < maxr; r++) {
       nextR = False;
       For (k = 1; (!nextR) && k ≤ maxk; k++) {
         nextR = (Mod[nk, r] == 1 || Mod[nk, r]==0)
       }
     }
     r--; (*the loop over increments by one*)
      
     r = 29

   (* Step 3 *)
   If (1 < gcd(a,n) < n for some ar), 
     output composite.
     For (a = r; a > 1; a--) {
       If ((gcd = GCD[a,n]) > 1 && gcd < n), 
         Return[Composite]
     }
      
     gcd = {GCD(29,31)=1, GCD(28,31)=1, ..., GCD(2,31)=1} ≯ 1

   (* Step 4 *)
   If (nr), 
     output prime.
     If (n ≤ r), 
       Return[Prime] (* this step may be omitted if n > 5690034 *)
      
     31 > 29
   
   (* Step 5 *)
   For a = 1 to  do
     If ((X+a)nXn + a (mod Xr − 1,n)), 
       output composite;
      
     φ[x_] := EulerPhi[x];
     PolyModulo[f_] := PolynomialMod[PolynomialRemainder[f, xr-1, x], n];
     max = Floor[Log[2, n]φ[r]];
     For (a = 1; a ≤ max; a++) {
       If (PolyModulo[(x+a)n - PolynomialRemainder[xn+a, xr-1], x] ≠ 0) {
         Return[Composite]
       {
     }
      
     (x+a)31 =
       a31 +31a30x +465a29x2 +4495a28x3 +31465a27x4 +169911a26x5 +736281a25x6 +2629575a24x7 +7888725a23x8 +20160075a22x9 +44352165a21x10 +84672315a20x11 +141120525a19x12 +206253075a18x13 +265182525a17x14 +300540195a16x15 +300540195a15x16 +265182525a14x17 +206253075a13x18 +141120525a12x19 +84672315a11x20 +44352165a10x21 +20160075a9x22 +7888725a8x23 +2629575a7x24 +736281a6x25 +169911a5x26 +31465a4x27 +4495a3x28 +465a2x29 +31ax30 +x31
      
     PolynomialRemainder [(x+a)31, x29-1] =
       465a2 +a31 +(31a+31a30)x +(1+465a29)x2 +4495a28x3 +31465a27x4 +169911a26x5 +736281a25x6 +2629575a24x7 +7888725a23x8 +20160075a22x9 +44352165a21x10 +84672315a20x11 +141120525a19x12 +206253075a18x13 +265182525a17x14 +300540195a16x15 +300540195a15x16 +265182525a14x17 +206253075a13x18 +141120525a12x19 +84672315a11x20 +44352165a10x21 +20160075a9x22 +7888725a8x23 +2629575a7x24 +736281a6x25 +169911a5x26 +31465a4x27 +4495a3x28
      
     (A) PolynomialMod [PolynomialRemainder [(x+a)31, x29-1], 31] = a31+x2
      
     (B) PolynomialRemainder [x31+a, x29-1] = a+x2
      
     (A) - (B) = a31+x2 - (a+x2) = a31-a
      
     
      
     {131-1 = 0 (mod 31), 231-2 = 0 (mod 31), 331-3 = 0 (mod 31), ..., 2631-26 = 0 (mod 31)}
   
   (* Step 6 *)
   Output prime.
     31 Must be Prime

Where PolynomialMod is a term-wise modulo reduction of the polynomial. e.g. PolynomialMod[x+2x2+3x3, 3] = x+2x2+0x3

[6]

References

  1. ^ a b c d e f Agrawal, Manindra; Kayal, Neeraj; Saxena, Nitin (2004). "PRIMES is in P" (PDF). Annals of Mathematics. 160 (2): 781–793. doi:10.4007/annals.2004.160.781. JSTOR 3597229.
  2. ^ Granville, Andrew (2005). "It is easy to determine whether a given integer is prime". Bull. Amer. Math. Soc. 42: 3–38. doi:10.1090/S0273-0979-04-01037-7.
  3. ^ H. W. Lenstra Jr. and Carl Pomerance, "Primality testing with Gaussian periods", preliminary version July 20, 2005.
  4. ^ H. W. Lenstra Jr. and Carl Pomerance, "Primality testing with Gaussian periods Archived 2012-02-25 at the Wayback Machine", version of April 12, 2011.
  5. ^ Daniel J. Bernstein, "Proving Primality After Agrawal-Kayal-Saxena", version of January 25, 2003.
  6. ^ See AKS Talk page for a discussion on why 'Example 2: n is not Prime past Step 4' is missing.

Further reading

Read other articles:

Provinsi Podkarpacie provinsi di Polandia województwo podkarpackie (pl) flag of Podkarpackie Voivodeship (en) coat of arms of the Subcarpathian Voivodeship (en) Dinamakan berdasarkanSubkarpatia Tempat <mapframe>: Judul Poland/Subcarpathian.map .map bukan merupakan halaman data peta yang sahcategoria:Articles mancats de coordenades Negara berdaulatPolandia NegaraPolandia Ibu kotaRzeszów Pembagian administratifPrzeworsk County (en) Ropczyce-Sędziszów County (en) Rzeszów County (en) S...

 

ForlìKomuneComune di ForlìPiazza SaffiNegara ItaliaWilayahEmilia-RomagnaProvinsiForlì-Cesena (FC)Frazionilihat daftarPemerintahan • Wali kotaRoberto Balzani (Partito Democratico)Luas • Total228 km2 (88 sq mi)Ketinggian34 m (112 ft)Populasi (30 April 2009) • Total116.864 • Kepadatan510/km2 (1,300/sq mi)DemonimForlivesiZona waktuUTC+1 (CET) • Musim panas (DST)UTC+2 (CEST)Kode pos47121-47122Kod...

 

H.Bachtiar Djafar, Wali Kota Medan Ke-13Masa jabatan1 April 1990 – 31 Maret 2000PresidenSoehartoBJ HabibieAbdurrahman WahidGubernurRaja Inal SiregarTengku Rizal Nurdin PendahuluH. Agus Salim RangkutiPenggantiAbdillah Informasi pribadiLahir(1939-07-27)27 Juli 1939Medan, Sumatera UtaraMeninggal3 Agustus 2021(2021-08-03) (umur 82)Medan, Sumatera UtaraKebangsaanIndonesiaPartai politikGolkarSunting kotak info • L • B Haji Bachtiar Djafar (27 Juli 1939 –...

2005 documentary film Mad Hot BallroomTheatrical release posterDirected byMarilyn AgreloWritten byAmy SewellProduced by Marilyn Agrelo Amy Sewell Brian David Cange Wilder Knight II StarringMadeleine HackneyCinematographyClaudia Raschke-RobinsonEdited bySabine KrayenbuhlMusic by Joseph Baker Steven Lutvak ProductioncompaniesParamount ClassicsNickelodeon MoviesJust One ProductionsDistributed byParamount ClassicsRelease date May 13, 2005 (2005-05-13) Running time106 minutesCountry...

 

1875 law in the US The Specie Payment Resumption Act of January 14, 1875 was a law in the United States that restored the nation to the gold standard through the redemption of previously unbacked United States Notes and reversed inflationary government policies promoted directly after the American Civil War. The decision further contracted the nation's money supply and was seen by critics as an exacerbating factor of the so-called Long Depression, which struck in 1873. History Late in 1861, s...

 

San Sperate Santu SparàuKomuneComune di San SperateLokasi San Sperate di Provinsi Sardinia SelatanNegara ItaliaWilayah SardiniaProvinsiSardinia Selatan (SU)Pemerintahan • Wali kotaEnrico ColluLuas • Total26,24 km2 (10,13 sq mi)Ketinggian41 m (135 ft)Populasi (2016) • Total8,312[1]Zona waktuUTC+1 (CET) • Musim panas (DST)UTC+2 (CEST)Kode pos09026Kode area telepon070Situs webhttp://www.sansperate.net San...

Dutch racing cyclist (born 1993) Laura SmuldersPersonal informationNationalityDutchBorn (1993-12-09) 9 December 1993 (age 30)[1]Nijmegen, NetherlandsWebsiteLauraSmulders.nlSportSportCyclingEventBMX racing Medal record Women's BMX racing Representing  Netherlands Event 1st 2nd 3rd Olympic Games 0 0 1 World Championships 2 2 2 World Cup 5 1 2 World Cup stage 27 6 6 European Championships 4 0 1 Total 38 9 12 Olympic Games 2012 London BMX racing World Championships 2014 Rotterda...

 

Isih penak jamanku to? (Indonesia: masih enak zaman saya 'kan?code: id is deprecated ) atau piye kabare, isih penak jamanku to? (Indonesia: apa kabar, masih enak zaman saya 'kan?code: id is deprecated ) adalah sebuah slogan dalam bahasa Jawa yang menyatakan bahwa zaman pemerintahan Presiden Indonesia Soeharto lebih baik daripada zaman sekarang.[1] Slogan ini telah muncul pada tahun 2013 di stiker, kaos, dan internet.[2] Slogan ini juga dapat ditemukan di baliho kampanye politi...

 

Saul LiebermanLahirMei 28, 1898 MeninggalMaret 23, 1983  (aged 84)PekerjaanFilolog PenghargaanPenghargaan Harvey (sains) (Amerika Serikat, For investigations into the civilizations of the peoples of the Middle East in the Hellenistic and Roman periods, and for his great and profound commentaries on the sources of Talmudic literature., 1976)  Saul Lieberman (Ibrani: שאול ליברמן, 28 Mei 1898 – 23 Maret 1983), juga dikenal sebagai Rabi Shaul Lieberma...

This article is about the 1850s and 1860s political party. For the 1864 presidential political party, see National Union Party (United States). For the 1936 political party, see Union Party (United States). Political party in United States Unionist Party LeadersAlexander H. StephensRobert ToombsFrancis P. Blair Jr.Thomas SwannJohn P. KennedyFoundedAugust 7, 1852; 171 years ago (1852-08-07)February 28, 1861; 163 years ago (1861-02-28) (Unconditional)Diss...

 

Jeff BuckleyNama lahirJeffrey Scott BuckleyLahir(1966-11-17)17 November 1966AsalAnaheim, California, ASGenreRockRock AlternatifPekerjaanPenyanyi-penulis laguInstrumenVokal, gitarTahun aktif1991–1997LabelColumbiaArtis terkaitTim Buckley, The A.M., Shinehead, Gods and MonstersSitus webwww.jeffbuckley.com Jeffrey Scott Buckley (17 November 1966 – 29 Mei 1997), ketika kecil dipanggil Scotty Moorhead,[1] adalah penyanyi, penulis lagu, dan pemain gitar Amerika Serikat. Ia adalah anak da...

 

Il laboratorio di Dexterserie TV d'animazione Titolo orig.Dexter's Laboratory Lingua orig.inglese PaeseStati Uniti AutoreGenndy Tartakovsky RegiaGenndy Tartakovsky, Rob Renzetti, Chris Savino, Don Judge StudioCartoon Network Studios (2001-2003), Hanna-Barbera (1996-1999) ReteCartoon Network 1ª TV27 aprile 1996 – 20 novembre 2003 Episodi78 (completa) Durata ep.22 min Rete it.TELE+1 (st. 1), Italia 1 (st. 2), Cartoon N...

Тамга племени чепни согласно М. Кашгари Чепни (также: джебни; туркм. Çepni) - историческое туркменское племя из списка 24-х огузо-туркменских племен, ведущих происхождение от внуков древнего родоначальника туркмен Огуз-хана. Содержание 1 Происхождение 2 История 3 Этнонимия 4 П�...

 

Gambling that involves the drawing of numbers at random for a prize Not to be confused with the Mexican game of chance Lotería. For other uses, see Lottery (disambiguation) and Lottery ticket (disambiguation). This article may need to be rewritten to comply with Wikipedia's quality standards. You can help. The talk page may contain suggestions. (July 2022) A lottery drawing being conducted at the television studio at Texas Lottery Commission headquarters Lottery tickets for sale, Ropar, Indi...

 

Local government elections in Bristol, England Bristol City Council is the local authority for Bristol, a unitary authority and ceremonial county in England. Until 1 April 1996 it was a non-metropolitan district in Avon. From 2012 until 2024 it also had a directly elected mayor. Because of the 2020 COVID-19 pandemic, elections for the Mayor of Bristol, Bristol City Council councillors, and the Avon and Somerset Police and Crime Commissioner were delayed from 2020 to May 2021, with post holder...

Margaretha Krook Margaretha Krook under tidigt 1960-tal.FöddMargaretha Knutsdotter Krook15 oktober 1925Maria Magdalena församling,Södermalm, Stockholm, SverigeDöd7 maj 2001 (75 år)Oscars församling,Östermalm, Stockholm, SverigeAktiva år1949–2001MakeStig Hammar (1956–1981)Betydande rollerFlora i Släpp fångarne loss – det är vår! Konsulinnan Ahlhagen i Morrhår och ärtorGuldbaggen Bästa kvinnliga huvudroll 1976 – Släpp fångarne loss – det är vår!IMDb SFDb M...

 

يفتقر محتوى هذه المقالة إلى الاستشهاد بمصادر. فضلاً، ساهم في تطوير هذه المقالة من خلال إضافة مصادر موثوق بها. أي معلومات غير موثقة يمكن التشكيك بها وإزالتها. (أغسطس 2019) الدوري الفلسطيني الممتاز لقطاع غزة الموسم 2017–18 البلد  فلسطين النسخة 12 عدد الفرق 12 الفائز شباب خانيونس (...

 

Japanese political party This article is part of a series onPolitics of Japan Constitution and Laws Constitution of Japan (1947–present) Meiji Constitution (1890–1947) Laws The Monarchy The Emperor (List) Naruhito Crown Prince Fumihito Imperial House Chrysanthemum Throne Imperial Succession Imperial Household Agency Executive Government Prime Minister (List) Fumio Kishida (LDP) Cabinet (List) Second Kishida Cabinet (Second Reshuffle)(LDP-Komeito coalition) Ministries Administrative Agenci...

Jamaican reggae group This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: The Original Wailers – news · newspapers · books · scholar · JSTOR (June 2016) (Learn how and when to remove this message) The Original WailersOriginKingston, JamaicaGenresReggaeYears active2008 – presentLabelsMRG RecordingsSpinoff ofBob...

 

Glacier on Mount Olympus in the U.S. Hoh GlacierAerial view of Hoh GlacierHoh GlacierTypeMountain glacierLocationMount Olympus, Olympic National Park, Jefferson County, Washington, USACoordinates47°47′54″N 123°40′13″W / 47.79833°N 123.67028°W / 47.79833; -123.67028[1]Length3.06 miles (4.93 km)[2] Hoh Glacier is a glacier on Mount Olympus in the Olympic National Park in Jefferson County of the U.S. state of Washington.[3] It is t...