Algorithme de Cornacchia
En mathématiques, l'algorithme de Cornacchia est une procédure pour résoudre certaines équations diophantiennes généralisant l'équation de Pell-Fermat. Cet algorithme est nommé d'après le mathématicien italien Giuseppe Cornacchia qui l'a introduit en 1908[1], et parfois également attribué au mathématicien irlandais Henry Smith, sous le nom d'algorithme de Cornacchia-Smith[2]Modèle:,[3]. Plus spécifiquement, l'algorithme fournit une solution entière de l'équation , où , et les entiers et sont premiers entre eux.
Cet algorithme est d'un intérêt pratique majeur, car il permet notamment de trouver une représentation d'un premier comme la norme d'un élément d'une extension quadratique, une étape essentielle par exemple dans la preuve de primalité par courbes elliptiques. Pour cette tâche, l'algorithme de Cornacchia est plus efficace que les méthodes génériques à base de formes quadratiques ou de réduction de réseaux euclidiens[4]Modèle:,[5]. Une autre utilisation importante de l'algorithme de Cornacchia est la génération de courbes elliptiques à multiplication complexe[6].
Description de l'algorithme
Soit donc l'équation , où , et les entiers et sont premiers entre eux. On suppose également premiers entre eux.
On obtient d'abord tel que , en utilisant n'importe quelle méthode de calcul de racines carrées modulaires. Si n'est pas un résidu quadratique modulo , l'équation de départ n'a pas de solution. Puis on déploie l'algorithme d'Euclide étendu sur la paire , ce qui donne la séquence suivante :
On arrête lorsque l'on atteint un rang tel que . Si , l'équation de départ n'a pas de solution. Dans le cas contraire, on vérifie que est un carré. Si ce n'est pas le cas, l'équation de départ n'a pas de solution. Sinon, on conclut en exhibant une solution
Les solutions de ce type sont dites primitives. Si maintenant on ne suppose plus premiers entre eux, alors ! en particulier, si est sans carrés, toutes les solutions de l'équation sont primitives. Sinon, on note tel que et on résout l'équation avec . Une solution non-primitive est alors obtenue en prenant .
La description de Cornacchia ne contenait pas de preuve que cet algorithme est correct. Il a fallu pour cela attendre la fin du Modèle:20e siècle, et plusieurs preuves très différentes ont depuis été proposées[7]Modèle:,[8]Modèle:,[9], dont un argument élégant de François Morain par réduction au problème de Thue[10]. L'algorithme de Cornacchia s'étend aisément à des anneaux plus larges que , notamment l'anneau des entiers de Gauss[11].
Références
Modèle:Références Modèle:Portail
- ↑ Modèle:Article
- ↑ Modèle:Ouvrage
- ↑ Modèle:Article
- ↑ Modèle:Article
- ↑ Modèle:Ouvrage
- ↑ Modèle:Ouvrage
- ↑ Modèle:Article
- ↑ Modèle:Article
- ↑ Modèle:Article
- ↑ François Morain (dir. Jean-Louis François), Courbes elliptiques et tests de primalité, Lyon, Université Claude Bernard (thèse de doctorat en sciences), 1990, 187 p, Chapitre 2.
- ↑ Modèle:Article