Pollard's
-Method
Lenstra's discovery of ECM was inspired by
Pollard's
-method, which we describe in this section.
Definition 6.3 (Power smooth)
Let
data:image/s3,"s3://crabby-images/13e77/13e7756d568fdc33b459d8d15029d8d075961714" alt="$ B$"
be a positive
integer. If
data:image/s3,"s3://crabby-images/38c64/38c642b24a58d464653328e3aca9f42019f2003d" alt="$ n$"
is a positive integer with prime factorization
data:image/s3,"s3://crabby-images/1160c/1160ce22bcdf4c6afea63f1b8a1c635f8caa790e" alt="$ n=\prod p_i^{e_i}$"
, then
data:image/s3,"s3://crabby-images/38c64/38c642b24a58d464653328e3aca9f42019f2003d" alt="$ n$"
is
-power smooth if
data:image/s3,"s3://crabby-images/21ac8/21ac8a6b358f79e2af448530b3659ea1e0b2b1c0" alt="$ p_i^{e_i}\leq B$"
for all
data:image/s3,"s3://crabby-images/adb2b/adb2b44c5b1a2d48f909ab751a579f962c748820" alt="$ i$"
.
Thus
is
power smooth for
, but
is not
-power smooth (it is
-power
smooth).
We will use the following algorithm in both the Pollard
and elliptic curve factorization methods.
Proof.
Let
data:image/s3,"s3://crabby-images/aff9d/aff9d224f906bd402d49ce0f428f0a3dde98a8a0" alt="$ m=\lcm (1,2,\ldots, B)$"
. Then
where
data:image/s3,"s3://crabby-images/62ee7/62ee7f1646b186dba1f1ee5b5326f75c769fbd64" alt="$ p^r$"
is the largest power of
data:image/s3,"s3://crabby-images/56c61/56c61b4f72ec86661c34b86478fae7dc83441d29" alt="$ p$"
that satisfies
data:image/s3,"s3://crabby-images/b2d63/b2d63d4e615b27296e9fa0cf6aa8e5c11cbd4e36" alt="$ p^r\leq B$"
.
Since
data:image/s3,"s3://crabby-images/16ade/16ade257818110255a07843883b65e783fded2ff" alt="$ p^r\leq B < p^{r+1}$"
, we have
data:image/s3,"s3://crabby-images/5d552/5d552a978bd0f11082777a9dd2ffe8188ea5d3ce" alt="$ r=\lfloor \log_p(B) \rfloor$"
.
Let
be a positive integer that we wish to factor. We use the
Pollard
-method to look for a nontrivial factor of
as
follows. First we choose a positive integer
, usually with at most
six digits. Suppose that there is a prime divisor
of
such that
is
-power smooth. We try to find
using the following strategy. If
is an integer
not divisible by
then by Theorem 2.1.19,
Let
, and observe that our assumption that
is
-power smooth implies that
, so
Thus
If
also then
is a nontrivial factor
of
.
If
, then
for every prime power
divisor
of
. In this case, repeat the above steps but with a
smaller choice of
or possibly a different choice of
.
Also, it is a good idea to check from the
start whether or not
is not a perfect power
, and if so
replace
by
. We formalize the algorithm as follows:
For fixed
, Algorithm 6.3.3
often splits
when
is divisible
by a prime
such that
is
-power smooth.
Approximately
15% of primes
in the interval from
and
are such that
is
power-smooth, so the Pollard method with
already fails nearly 85% of the time at finding
-digit
primes in this range (see also Exercise 6.10). We
will not analyze Pollard's method further, since it was mentioned here
only to set the stage for the elliptic curve factorization method.
The following examples illustrate the Pollard
-method.
Example 6.3
In this example, Pollard works perfectly.
Let
data:image/s3,"s3://crabby-images/50b8d/50b8dfccc2dd4f9a04cc7b3de4195a6ad187e5ff" alt="$ N=5917$"
. We try to use the Pollard
data:image/s3,"s3://crabby-images/1bace/1bace1c377b214ee890e2580f739afe1c9ccd043" alt="$ p-1$"
method with
data:image/s3,"s3://crabby-images/70105/701054914db6695ae1edd4ec3761b19ac2c5e56f" alt="$ B=5$"
to split
data:image/s3,"s3://crabby-images/aceb0/aceb0b91188b0db935e9de931fdac179521d7295" alt="$ N$"
. We have
data:image/s3,"s3://crabby-images/7e88b/7e88b98f3a8e3cb1fccee041c767f2cf33fe1eeb" alt="$ m = \lcm (1,2,3,4,5)=60$"
; taking
data:image/s3,"s3://crabby-images/dd820/dd8201f10f985f529a23a27bb7aa373f336db1b1" alt="$ a=2$"
we have
and
so
data:image/s3,"s3://crabby-images/8d879/8d879d223591f88018b1e838d9ea551a0959d1d0" alt="$ 61$"
is a factor of
data:image/s3,"s3://crabby-images/762e7/762e7c8feae36c54d4392804aa7d589f19743e82" alt="$ 5917$"
.
Example 6.3
In this example, we replace
data:image/s3,"s3://crabby-images/13e77/13e7756d568fdc33b459d8d15029d8d075961714" alt="$ B$"
by larger integer.
Let
data:image/s3,"s3://crabby-images/94e0a/94e0a86580ae2cec16a80385b6750720b202e385" alt="$ N=779167$"
. With
data:image/s3,"s3://crabby-images/70105/701054914db6695ae1edd4ec3761b19ac2c5e56f" alt="$ B=5$"
and
data:image/s3,"s3://crabby-images/dd820/dd8201f10f985f529a23a27bb7aa373f336db1b1" alt="$ a=2$"
we have
and
data:image/s3,"s3://crabby-images/3e5cd/3e5cd93fae295d860f20fb2758c501d65953cbcb" alt="$ \gcd(2^{60}-1,779167) = 1.$"
With
data:image/s3,"s3://crabby-images/d8d51/d8d519f8763d7e974399cbee5529a9f855b2b789" alt="$ B=15$"
, we have
and
so
data:image/s3,"s3://crabby-images/46c25/46c25ca22b20ebbe91430ba9ec3a3dead687a5f3" alt="$ 2003$"
is a nontrivial factor of
data:image/s3,"s3://crabby-images/6c23b/6c23b74962ad0b790363f2a307a085d393aa191c" alt="$ 779167$"
.
Example 6.3
In this example, we replace
data:image/s3,"s3://crabby-images/13e77/13e7756d568fdc33b459d8d15029d8d075961714" alt="$ B$"
by a smaller integer.
Let
data:image/s3,"s3://crabby-images/46ebc/46ebcc5141f747a1d43b7620908ed7e979013db7" alt="$ N=4331$"
. Suppose
data:image/s3,"s3://crabby-images/8c059/8c0598f622b399606ceaf71cc4e74c4ae12ae803" alt="$ B=7$"
, so
data:image/s3,"s3://crabby-images/ec04d/ec04ddab10a4f78aab69f08ca3c7d97da2353d8b" alt="$ m=\lcm (1,2,\ldots,7)=420$"
,
and
data:image/s3,"s3://crabby-images/254c4/254c44ec5c11ba6ae6d942ac887a4ad4ad1158ee" alt="$ \gcd(2^{420} - 1, 4331) = 4331$"
,
so we do not obtain a factor of
data:image/s3,"s3://crabby-images/2b68c/2b68c322b941d9781b077096cc6203c6901cf0a6" alt="$ 4331$"
.
If we replace
data:image/s3,"s3://crabby-images/13e77/13e7756d568fdc33b459d8d15029d8d075961714" alt="$ B$"
by
data:image/s3,"s3://crabby-images/fc918/fc918ac31c6ebc06cba4c293ca35e0c1c354b62c" alt="$ 5$"
, Pollard's method works:
and
data:image/s3,"s3://crabby-images/de4bf/de4bffc70ede0330d67d8c34907132db118d3fc3" alt="$ \gcd(2^{60}-1,4331) = 61$"
,
so we split
data:image/s3,"s3://crabby-images/2b68c/2b68c322b941d9781b077096cc6203c6901cf0a6" alt="$ 4331$"
.
Example 6.3
In this example,
data:image/s3,"s3://crabby-images/dd820/dd8201f10f985f529a23a27bb7aa373f336db1b1" alt="$ a=2$"
does not work, but
data:image/s3,"s3://crabby-images/15d38/15d38d19c92a054eb3a7fcfd946adf0d5a2f2745" alt="$ a=3$"
does.
Let
data:image/s3,"s3://crabby-images/e644f/e644fb3f8541cf07408ce9a939bd674f777df9ff" alt="$ N=187$"
. Suppose
data:image/s3,"s3://crabby-images/d8d51/d8d519f8763d7e974399cbee5529a9f855b2b789" alt="$ B=15$"
, so
data:image/s3,"s3://crabby-images/37ae7/37ae7a39f63759d11ed22eb93f1756744a92f0f8" alt="$ m=\lcm (1,2,\ldots,15)=360360$"
,
and
data:image/s3,"s3://crabby-images/394e9/394e92c8aba4a8c874d8d85320a0bfcc1a6a7729" alt="$ \gcd(2^{360360} - 1, 187) = 187$"
,
so we do not obtain a factor of
data:image/s3,"s3://crabby-images/3bc7e/3bc7e9d7640691cccb1df39ec24c1f2fd67a6f8b" alt="$ 187$"
.
If we replace
data:image/s3,"s3://crabby-images/dd820/dd8201f10f985f529a23a27bb7aa373f336db1b1" alt="$ a=2$"
by
data:image/s3,"s3://crabby-images/15d38/15d38d19c92a054eb3a7fcfd946adf0d5a2f2745" alt="$ a=3$"
, then Pollard's method works:
and
data:image/s3,"s3://crabby-images/a7013/a7013336d80dc2864ee3076c69d408d9b35b4fa7" alt="$ \gcd(3^{360360}-1,187) = 11$"
. Thus
data:image/s3,"s3://crabby-images/07c51/07c515f0871190e0a104020264c5851372929c34" alt="$ 187 = 11\cdot 17$"
.
William
2007-06-01