I am aware that there are a number of primality testing algorithms used in practice (Sieve of Eratosthenes, Fermat’s test, Miller-Rabin, AKS, etc). However, they are either slow (e.g. sieve), probabalistic (Fermat and Miller-Rabin), or relatively difficult to implement (AKS).
What is the best deterministic solution to determine whether or not a number is prime?
Note that I am primarily (pun intended) interested in testing against numbers on the order of 32 (and maybe 64) bits. So a robust solution (applicable to larger numbers) is not necessary.
Up to
~2^30you could brute force with trial-division.Up to
3.4*10^14, Rabin-Miller with the first 7 primes has been proven to be deterministic.Above that, you’re on your own. There’s no known sub-cubic deterministic algorithm.
EDIT : I remembered this, but I didn’t find the reference until now:
http://reference.wolfram.com/legacy/v5_2/book/section-A.9.4
So if you implement Rabin-Miller and Lucas, you’re good up to 10^16.