Inom matematik är primalitetstestmetoder som använder elliptiska kurvor (eng. - Elliptic Curve Primality Proving , förkortning ECPP ) en av de snabbaste och mest använda metoderna för att testa för primat [1] . Denna idé lades fram av Shafi Goldwasser och Joe Kilian 1986; den förvandlades till A.O.L- algoritmen. Atkin samma år. Därefter har algoritmen modifierats och förbättrats flera gånger, framför allt av Atkin och François Morain 1993 [2] . Konceptet med att använda elliptisk kurvfaktorisering utvecklades av Hendrik Lenstra 1985 och följdes snart av dess användning för att testa och bevisa siffror för primalitet.
Primalitetstestet har funnits sedan Fermats tid , då de flesta algoritmer baserades på faktorisering , vilket blir otympligt när inputen är stor. Moderna algoritmer löser individuellt problemen med att avgöra om ett tal är primtal och vilka är dess faktorer . Med tillkomsten av den moderna utvecklingsperioden för kryptografi började detta få betydande praktisk betydelse. Även om många moderna test bara ger ett probabilistiskt resultat (eller visar att N är sammansatt, eller förmodligen primtal , som till exempel med Miller-Rabin-testet ), visar den elliptiska kurva-testet att ett tal är primtal (eller sammansatt) med hjälp av en snabbt verifierad certifikat [3] ( engelska ).
Primalitetstestet för elliptiska kurvor ger ett alternativ (bland annat) till Pocklington-testet, vilket kan vara svårt att implementera i praktiken. Det elliptiska kurvtestet baseras på kriterier som liknar Pocklington-testet , på vilket motsvarande test baseras [4] . Vi formulerar nu ett förslag på grundval av vilket vårt test, som liknar Pocklington-kriteriet, och ger upphov till Goldwasser-Kilian-Atkin-testet av det elliptiska primalitetskurvatestet.
Det är en allmän algoritm , vilket innebär att den inte är beroende av speciella formnummer. För närvarande är ECPP, i praktiken, den snabbaste kända algoritmen för att kontrollera primaliteten hos siffror, men den värsta exekveringstiden (den maximala tiden under vilken en uppgift kan slutföras på en viss hårdvaruplattform) är inte känd. ESRR fungerar i tid: [5]
för vissa . Av heuristiska skäl kan denna indikator reduceras till i vissa fall. ECPP fungerar på samma sätt som de flesta andra primatitetstester , hittar en grupp och visar att dess storlek är sådan att den är prime. För ECPP är en grupp en elliptisk kurva över en ändlig uppsättning kvadratiska former som är trivial med avseende på gruppfaktorn*(?).
ECPP genererar ett Atkin-Goldwaser-Kilian-Morain-primalitetscertifikat med hjälp av rekursion och försöker sedan verifiera certifikatet. Det steg som tar mest CPU- tid är att generera certifikatet, eftersom faktoriseringen måste utföras på klassfältet . Certifikatet kan valideras snabbt, vilket gör fördröjningen för denna operation mycket kort.
Från och med september 2015 är det största primtal [6] som hittades med ECPP-metoden ett värde på 30950 siffror, vilket betecknas i termer av Lucas-sekvensen som:
Det tog Paul Underwood 9 månader att få den certifierad med Primo (Marcel Martins mjukvara).
Låt N vara ett positivt heltal och E en mängd, som bestäms av formeln . Betrakta E över , med den vanliga additionslagen på E , och skriv 0 som det neutrala elementet på E .
Låt m vara ett heltal. Om det finns ett primtal q som är en divisor av m och större än och det finns en punkt P på E så att
(1) mP = 0
2) ( m / q ) P är definierat och inte lika med 0
Då är N ett primtal.
Om N är sammansatt, så finns det ett primtal som delar N. Vi definierar det som en elliptisk kurva definierad av samma ekvation som E , men vi definierar den modulo p , inte modulo N. Låt oss definiera som gruppens ordning . Genom Hasses sats om elliptiska kurvor vet vi
och alltså gcd , och det finns ett heltal u med egenskapen
Låt det finnas en punkt P uppskattad modulo p. Alltså på vi har
använder (1), eftersom beräknas med samma metoder som mP , förutom modulen för p snarare än modulen för N (och ).
Detta motsäger (2), eftersom om ( m/q ) P är definierad och inte är lika med 0 (mod N ), så kommer samma metod modulo p snarare än mod N att ge
Från detta påstående kan en algoritm konstrueras för att bevisa att heltal N är primtal. Detta görs på följande sätt:
Vi väljer tre slumpmässiga heltal a, x, y och mängd
Låt nu P = ( x , y ) vara en punkt som hör till E , där E definieras som . Därefter behöver vi en algoritm för att räkna antalet poäng på E. Tillämpad på E kommer denna algoritm (Koblitz och andra föreslår Schufs algoritm [en algoritm för att räkna punkter i en elliptisk kurva över ett ändligt fält]) ge ett tal m som uttrycker antalet punkter på kurvan E över F N , förutsatt att N är prime. Därefter har vi ett kriterium för att avgöra om vår kurva E är acceptabel.
Om vi kan skriva m som där är ett litet heltal och q antagligen är primtal (till exempel klarade den några tidigare probabilistiska primalitetstester ) , så kasserar vi inte E. Om det inte går att skriva m i det här formuläret, kasserar vi vår kurva och väljer slumpmässigt en annan trippel ( a, x, y ) för att börja om.
Anta att vi har hittat en kurva som passerar under kriteriet, sedan fortsätter vi med att beräkna mP och kP . Om vi i något skede av beräkningen stöter på ett odefinierat uttryck (från beräkningen av P eller i algoritmen för att räkna antalet poäng), ger detta oss en icke-trivial faktor N.
Om , då blir det tydligt att N inte är primtal, för om N var primtal skulle E ha ordningen m , och vilket element av E som helst skulle bli 0 när det multipliceras med m . Om Kp = 0, så hamnar vi i en återvändsgränd och måste börja om med ytterligare en trippel.
Nu, om och , då vårt tidigare uttalande säger oss att N är primtal. Det finns dock ett möjligt problem, vilket är enkelheten i q . Detta måste verifieras med samma algoritm. Sålunda har vi beskrivit ett steg-för-steg-förfarande där primeness av N kan bevisas med primeness av q och små troliga primeness, upprepa tills vi når vissa primeness och avslutar. [8] [9]
Atkin och Moraine sa att "problemet med Goldwasser-Kilian-algoritmen är att Schouf-algoritmen är nästan omöjlig att implementera." [10] Det är mycket långsamt och krångligt att beräkna alla punkter på E med Schuf-algoritmen, som är den föredragna algoritmen för Goldwasser-Kilian-algoritmen. Schoofs ursprungliga algoritm är dock inte tillräckligt effektiv för att ge beräkningen av antalet poäng under en kort tidsperiod. [11] Dessa kommentarer måste ses i ett historiskt sammanhang, före Elkis och Atkins förbättring av Schuf-metoden.
I en artikel från 1993 beskrev Atkin och Moraine en ECPP-algoritm som undviker svårigheterna med att använda en algoritm som bygger på en besvärlig poängräkning (Schoofs algoritm). Algoritmen förlitar sig fortfarande på påståendena ovan, men istället för att generera elliptiska kurvor slumpmässigt och sedan hitta rätt m , är deras idé att bygga en kurva E på vilken det är lätt att beräkna antalet punkter. Komplex multiplikation är nyckeln i kurvkonstruktion.
Nu, givet ett visst N , vars enkelhet måste bevisas, måste vi hitta lämpliga m och q , precis som i Goldwasser-Kilian-algoritmen, som kommer att uppfylla satsen och bevisa enkelheten hos N . (naturligtvis måste också punkten P och själva kurvan, E , hittas)
ECPP använder komplex multiplikation för att bygga kurvan E , denna metod gör det enkelt att beräkna m (antal punkter på E ). Låt oss nu beskriva denna metod:
Användningen av komplex multiplikation kräver en negativ diskriminant , D, så att D kan skrivas som en produkt av två element , eller, helt ekvivalent, vi kan skriva ekvationen:
För vissa a, b . Om vi kan beskriva N i termer av någon av dessa former, kan vi skapa en elliptisk kurva E på med komplex multiplikation (detaljerad nedan), och antalet poäng ges av:
För att dela upp N i två element måste vi göra det (där betecknar Legendre-symbolen ). Detta är ett nödvändigt villkor, och vi kommer att uppnå tillräcklighet om ordningen för gruppen h (D) i är 1. Detta händer bara för de 13 värdena av D, som är elementen {-3, -4, -7 , -8, -11, -12, -16, -19, -27, -28, -43, -67, -163}