PrimalityProving`
PrimalityProving`
ProvablePrimeQ
Details and Options
- To use ProvablePrimeQ, you first need to load the Primality Proving Package using Needs["PrimalityProving`"].
- When ProvablePrimeQ[n] returns True, then n is prime based on the Pratt certificate of primality or the Atkin–Morain certificate of primality.
- ProvablePrimeQ should not be used as a replacement for PrimeQ, as PrimeQ is several orders of magnitude faster. Instead, use ProvablePrimeQ to certify the results of PrimeQ when needed.
- The following options can be given:
-
"SmallPrime" 1050 lower bound for using the Atkin–Morain test "Certificate" False whether to print a certificate "PollardPTest" Automatic whether to use the Pollard method
"PollardRhoTest" Automatic whether to use the Pollard method
"TrialDivisionLimit" Automatic number of primes to use in trial division "PrimeQMessages" False whether progress is to be monitored
Examples
open allclose allBasic Examples (1)Summary of the most common use cases
In[1]:=1
data:image/s3,"s3://crabby-images/c34d1/c34d15234bfa258d59058b03954fb10760f6f73e" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-db6dyf
PrimeQ indicates that 1093 is prime:
In[2]:=2
data:image/s3,"s3://crabby-images/26910/26910a82fab22aecac5edd3cc2093a80cf423a5e" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-hqi
Out[2]=2
data:image/s3,"s3://crabby-images/42faa/42faab9845a445ea4dc5e9ec2c8e2a36d358bdd3" alt=""
ProvablePrimeQ gives the same result, but it has generated a certificate:
In[3]:=3
data:image/s3,"s3://crabby-images/71e78/71e782ecc546729c0331c16c354d037355d765ca" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-xuk
Out[3]=3
data:image/s3,"s3://crabby-images/d0e61/d0e61110961a5c4ffd893964dd18b0e68fe974a1" alt=""
Scope (2)Survey of the scope of standard use cases
In[1]:=1
data:image/s3,"s3://crabby-images/ded73/ded738e4b3d5594b4150ef14ca098002393224ad" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-hv7lri
ProvablePrimeQ works on arbitrarily large numbers:
In[2]:=2
data:image/s3,"s3://crabby-images/eeaf1/eeaf1b5a6556f0b409ec7eadf7e58a860a552d0a" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-vtiy0j
Out[2]=2
data:image/s3,"s3://crabby-images/e8134/e81346d28699d6eae0fe61671ca82b8a5a2533c9" alt=""
In[1]:=1
data:image/s3,"s3://crabby-images/4660b/4660b67b92d871aaa596f88cbe2d0dbb1e749f17" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-qekr3r
ProvablePrimeQ automatically threads over lists:
In[2]:=2
data:image/s3,"s3://crabby-images/dcb26/dcb26111fb695fa58a75eb9dd2af490e9b5c3647" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-jzkvr
Out[2]=2
data:image/s3,"s3://crabby-images/3d6bb/3d6bb352990b917171933769939c32e62bbe1411" alt=""
Options (2)Common values & functionality for each option
Certificate (1)
In[1]:=1
data:image/s3,"s3://crabby-images/6be87/6be87f2146aa7fe361f6be5625f9760101709f2f" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-begaws
Use the option "Certificate"->True to view the certificate directly:
In[2]:=2
data:image/s3,"s3://crabby-images/45a8f/45a8fd8dbe03727f46ebad8459a839ab8fbcfa85" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-bm3
Out[2]=2
data:image/s3,"s3://crabby-images/5bcb5/5bcb5e9913b8959e7121cfee6b2753b31c58eb2f" alt=""
PrimeQMessages (1)
In[1]:=1
data:image/s3,"s3://crabby-images/e3da4/e3da4815ff6ba00d092dd547021896057dd83c76" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-fgqpks
In[2]:=2
data:image/s3,"s3://crabby-images/7b7ae/7b7aef0a76b2ad46dabc443c1684f4f3724492cd" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-oet
Out[2]=2
data:image/s3,"s3://crabby-images/9b43d/9b43d2a98a7cf0e9c2586e59cbad502a8aa91967" alt=""
Progress messages are printed with "PrimeQMessages"->True:
In[3]:=3
data:image/s3,"s3://crabby-images/67e88/67e88f19ca74d80166feb4d7baad608dee29365f" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-bv1
Out[3]=3
data:image/s3,"s3://crabby-images/9d86a/9d86a8a102339f3b2cc07c66350edb23d4ea9284" alt=""
Properties & Relations (1)Properties of the function, and connections to other functions
In[1]:=1
data:image/s3,"s3://crabby-images/4897a/4897a78284b93c87c55cf1f2fa61e053c4de277a" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-d5tdbt
In[2]:=2
data:image/s3,"s3://crabby-images/b4085/b4085725c9a88777ef87aec556c19c4ffc0df62d" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-ehy
Out[2]=2
data:image/s3,"s3://crabby-images/80663/80663b26fee10cd0f09dbb8db4a192038ba1c0b5" alt=""
If ProvablePrimeQ has returned a result, use PrimeQCertificate to print the certificate:
In[3]:=3
data:image/s3,"s3://crabby-images/91b54/91b54fcaa782b335b5f8e0edea7a2d5c9e4f80ce" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-n2k
Out[3]=3
data:image/s3,"s3://crabby-images/bc62f/bc62f88c87bde36f5fd48122b8a02f5a8cf75320" alt=""
In[4]:=4
data:image/s3,"s3://crabby-images/fe772/fe7720bafc75f7704b42abb557042145f07c2f85" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-w2d
Out[4]=4
data:image/s3,"s3://crabby-images/01160/01160c8ed95f9f46b7d9d0ee0762c9144e8897de" alt=""
With "Certificate"->True, ProvablePrimeQ repeats the Atkin–Morain primality test:
In[5]:=5
data:image/s3,"s3://crabby-images/8a4fb/8a4fb3e45a06b271587a203dba300516b2f95e65" alt=""
✖
https://wolfram.com/xid/005n3yzmn9pvj57al3ids8gxq2b-ek5
Out[5]=5
data:image/s3,"s3://crabby-images/bdcce/bdcce14de1d766f7d9d1e676d2240b274fb4ecb3" alt=""