stringtranslate.com

Prueba de primalidad de Lucas

En la teoría de números computacionales , la prueba de Lucas es una prueba de primalidad para un número natural n ; requiere que los factores primos de n − 1 ya sean conocidos. [1] [2] Es la base del certificado Pratt que da una verificación concisa de que n es primo.

Conceptos

Sea n un entero positivo. Si existe un entero a , 1 <  a  <  n , tal que

y para cada factor primo q de n  − 1

entonces n es primo. Si no existe tal número a , entonces n es 1, 2 o compuesto .

La razón de la corrección de esta afirmación es la siguiente: si la primera equivalencia se cumple para a , podemos deducir que a y n son coprimos . Si a también sobrevive al segundo paso, entonces el orden de a en el grupo ( Z / n Z )* es igual a n −1, lo que significa que el orden de ese grupo es n −1 (porque el orden de cada elemento de un grupo divide el orden del grupo), lo que implica que n es primo . Por el contrario, si n es primo, entonces existe una raíz primitiva módulo n , o generador del grupo ( Z / n Z )*. Tal generador tiene orden |( Z / n Z )*| =  n −1 y ambas equivalencias se cumplirán para cualquier raíz primitiva de ese tipo.

Nótese que si existe un a  <  n tal que la primera equivalencia falla, a se denomina testigo de Fermat para la composición de n .

Ejemplo

Por ejemplo, tomemos n = 71. Entonces n  − 1 = 70 y los factores primos de 70 son 2, 5 y 7. Seleccionamos aleatoriamente un a=17  <  n . Ahora calculamos:

Para todos los números enteros a se sabe que

Por lo tanto, el orden multiplicativo de 17 (mod 71) no es necesariamente 70, ya que algún factor de 70 también puede funcionar arriba. Por lo tanto, verifique 70 dividido por sus factores primos:

Lamentablemente, obtenemos que 17 10 ≡1 (mod 71). Por lo tanto, aún no sabemos si 71 es primo o no.

Probamos otro a aleatorio , esta vez eligiendo a  = 11. Ahora calculamos:

Nuevamente, esto no demuestra que el orden multiplicativo de 11 (mod 71) sea 70, ya que algún factor de 70 también puede funcionar. Por lo tanto, verifiquemos 70 dividido por sus factores primos:

Entonces, el orden multiplicativo de 11 (mod 71) es 70 y, por lo tanto, 71 es primo.

(Para llevar a cabo estas exponenciaciones modulares , se podría utilizar un algoritmo de exponenciación rápida como la exponenciación binaria o la exponenciación en cadena de adición ).

Algoritmo

El algoritmo se puede escribir en pseudocódigo de la siguiente manera:

El algoritmo lucas_primality_test tiene  como entrada : n > 2, un entero impar que se va a probar para determinar su primalidad. k , un parámetro que determina la precisión de la prueba. salida : primo si n es primo, de lo contrario compuesto o posiblemente compuesto . determinar los factores primos de n −1. LOOP1: repetir  k veces: elige un al azar en el rango [2, n − 1] si  entonces   devuelve  compuesto  de lo contrario  #  LOOP2: para todos los factores primos q de n −1: si  entonces   si verificamos esta igualdad para todos los factores primos de n −1 entonces  devuelve  primo  de lo contrario  continúa LOOP2 de lo contrario  # continúa LOOP1   devolver  posiblemente compuesto .

Véase también

Notas

  1. ^ Crandall, Richard; Pomerance, Carl (2005). Números primos: una perspectiva computacional (2.ª ed.). Springer. pág. 173. ISBN 0-387-25282-7.
  2. ^ Křížek, Michal; Luca, Florian; Somer, Lawrence (2001). 17 Lecciones sobre números de Fermat: de la teoría de números a la geometría . CMS Books in Mathematics. Vol. 9. Sociedad Matemática Canadiense/Springer. pág. 41. ISBN. 0-387-95332-9.