Fermat's little theorem
For example, if a = 2 and p = 7, then 27 = 128, and 128 − 2 = 126 = 7 × 18 is an integer multiple of 7.
For example, if a = 2 and p = 7, then 26 = 64, and 64 − 1 = 63 = 7 × 9 is thus a multiple of 7.
Fermat's little theorem is the basis for the Fermat primality test and is one of the fundamental results of elementary number theory. The theorem is named after Pierre de Fermat, who stated it in 1640. It is called the "little theorem" to distinguish it from Fermat's last theorem.
If p is a prime and a is any integer not divisible by p, then a p − 1 − 1 is divisible by p.
In fact, the original statement was
Tout nombre premier mesure infailliblement une des puissances – 1 de quelque progression que ce soit, et l'exposant de la dite puissance est sous-multiple du nombre premier donné – 1 ; et, après qu'on a trouvé la première puissance qui satisfait à la question, toutes celles dont les exposants sont multiples de l'exposant de la première satisfont tout de même à la question.
This may be translated in modern terminology, with explanations and formulas inserted between brackets, for easier understanding:
Every prime number [p] divides necessarily one of the powers –1 of any [geometric] progression [a, a2, a3, ...] [that is there exists t such that p divides at – 1], and the exponent of this power [t] divides the given prime –1 [divides p – 1]; and, after one has found the first power [t] that satisfies the question, all those whose exponents are multiple of the exponent of the first one satisfy similarly the question [that is, all multiples of the first t have the same property].
Fermat did not consider the case where a is a multiple of p nor prove his assertion, only stating:
Et cette proposition est généralement vraie en toutes progressions et en tous nombres premiers; de quoi je vous envoierois la démonstration, si je n'appréhendois d'être trop long.
(And this proposition is generally true for all series [sic] and for all prime numbers; I would send you a demonstration of it, if I did not fear going on for too long.)
Euler provided the first published proof in 1736 in a paper entitled "Theorematum Quorundam ad Numeros Primos Spectantium Demonstratio" in the Proceedings of the St. Petersburg Academy, but Leibniz had given virtually the same proof in an unpublished manuscript from sometime before 1683.
The term "Fermat's Little Theorem" was probably first used in print in 1913 in Zahlentheorie by Kurt Hensel:
Für jede endliche Gruppe besteht nun ein Fundamentalsatz, welcher der kleine Fermatsche Satz genannt zu werden pflegt, weil ein ganz spezieller Teil desselben zuerst von Fermat bewiesen worden ist."
(There is a fundamental theorem holding in every finite group, usually called Fermat's little Theorem because Fermat was the first to have proved a very special part of it.)
Some mathematicians independently made the related hypothesis (sometimes incorrectly called the Chinese Hypothesis) that 2p ≡ 2 (mod p) if and only if p is a prime. Indeed, the "if" part is true, and is a special case of Fermat's little theorem. However, the "only if" part of this hypothesis is false: for example, 2341 ≡ 2 (mod 341), but 341 = 11 × 31 is a pseudoprime. See below.
Several proofs of Fermat's little theorem are known. It is frequently proved as a corollary of Euler's theorem.
where φ(n) denotes Euler's totient function (which counts the integers between 1 and n that are coprime to n). Euler's theorem is indeed a generalization, because if n = p is a prime number, then φ(p) = p − 1.
A slight generalization of Euler's theorem, which immediately follows from it, is: if a, n, x, y are integers with n positive and a and n coprime, then
- If , then .
This follows as x is of the form y + φ(n)k, so
In this form, the theorem finds many uses in cryptography and, in particular, underlies the computations used in the RSA public key encryption method. The special case with n a prime may be considered a consequence of Fermat's little theorem.
The algebraic setting of Fermat's little theorem can be generalized to finite fields.
The converse of Fermat's little theorem is not generally true, as it fails for Carmichael numbers. However, a slightly stronger form of the theorem is true, and is known as Lehmer's theorem. The theorem is as follows:
If there exists an a such that
and for all primes q dividing p − 1
then p is prime.
If a and p are coprime numbers such that a p − 1 − 1 is divisible by p, then p need not be prime. If it is not, then p is called a pseudoprime to base a (or a Fermat pseudoprime). F. Sarrus in 1820 found 341 = 11 × 31 as one of the first pseudoprimes, to base 2.
A number p that is a pseudoprime to base a for every number a coprime to p is called a Carmichael number (e.g. 561). Alternately, any number p satisfying the equality
is either a prime or a Carmichael number.
Miller–Rabin primality test
If p is an odd prime number, and p – 1 = 2s d, with d odd, then for every a prime to p, either ad ≡ 1 mod p, or there exists t such that 0 ≤ t < s and a2td ≡ −1 mod p
This result may be deduced from Fermat's little theorem by the fact that, if p is an odd prime, then the integers modulo p form a finite field, in which 1 has exactly two square roots, 1 and −1.
The Miller–Rabin test uses this property in the following way: given p = 2s d + 1, with d odd, an odd integer for which primality has to be tested, choose randomly a such that 1 < a < p; then compute b = ad mod p; if b is not 1 nor −1, then square it repeatedly modulo p until you get 1, −1, or have squared d times. If b ≠ 1 and −1 has not been obtained, then p is not prime. Otherwise, p may be prime or not. If p is not prime, the probability that this is proved by the test is higher than 1/4. Therefore, after k non-conclusive random tests, the probability that p is not prime is lower than (3/4)k, and may thus be made as low as desired, by increasing k.
In summary, the test either proves that a number is not prime, or asserts that it is prime with a probability of error that may be chosen as low as desired. The test is very simple to implement and computationally more efficient than all known deterministic tests. Therefore, it is generally used before starting a proof of primality.
- Long 1972, pp. 87–88.
- Pettofrezzo & Byrkit 1970, pp. 110–111.
- Burton 2011, p. 514.
- Fermat, Pierre (1894), Tannery, P.; Henry, C., eds., Oeuvres de Fermat. Tome 2: Correspondance, Paris: Gauthier-Villars, pp. 206–212 (in French)
- Mahoney 1994, p. 295 for the English translation
- Ore 1988, p. 273
- Albert 2015, p. 206
- Trappe, Wade; Washington, Lawrence C. (2002), Introduction to Cryptography with Coding Theory, Prentice-Hall, p. 78, ISBN 0-13-061814-4
- Rempe-Gillen, Lasse; Waldecker, Rebecca (2013-12-11). Primality Testing for Beginners. American Mathematical Soc. ISBN 9780821898833.
- Albert, A. Adrian (2015) , Modern higher algebra, Cambridge University Press, ISBN 978-1-107-54462-8
- Burton, David M. (2011), The History of Mathematics / An Introduction (7th ed.), McGraw-Hill, ISBN 978-0-07-338315-6
- Long, Calvin T. (1972), Elementary Introduction to Number Theory (2nd ed.), Lexington: D. C. Heath and Company, LCCN 77171950
- Mahoney, Michael Sean (1994), The Mathematical Career of Pierre de Fermat, 1601–1665 (2nd ed.), Princeton University Press, ISBN 978-0-691-03666-3
- Ore, Oystein (1988) , Number Theory and Its History, Dover, ISBN 978-0-486-65620-5
- Pettofrezzo, Anthony J.; Byrkit, Donald R. (1970), Elements of Number Theory, Englewood Cliffs: Prentice Hall, LCCN 71081766
- Paulo Ribenboim (1995). The New Book of Prime Number Records (3rd ed.). New York: Springer-Verlag. ISBN 0-387-94457-5. pp. 22–25, 49.
- János Bolyai and the pseudoprimes (in Hungarian)
- Fermat's Little Theorem at cut-the-knot
- Euler Function and Theorem at cut-the-knot
- Fermat's Little Theorem and Sophie's Proof
- Hazewinkel, Michiel, ed. (2001) , "Fermat's little theorem", Encyclopedia of Mathematics, Springer Science+Business Media B.V. / Kluwer Academic Publishers, ISBN 978-1-55608-010-4
- Weisstein, Eric W. "Fermat's Little Theorem". MathWorld.
- Weisstein, Eric W. "Fermat's Little Theorem Converse". MathWorld.