Finding Square Roots
We return in this section to the question of computing square roots.
If
is a field in which
, and
, with
,
then
the solutions to the quadratic equation
are
Now assume
, with
an odd prime. Using
Theorem 4.1.7, we can decide whether or not
is a
perfect square in
, and hence whether or not
has a solution in
. However
Theorem 4.1.7 says nothing about how to actually find
a solution when there is one.
Also, note that for this problem we do not need the
full quadratic reciprocity law; in practice to
decide whether an element of
is
a perfect square Proposition 4.2.1 is quite fast,
in view of Section 2.3.
Suppose
is a nonzero quadratic residue.
If
then
is a square root of
because
We can compute
in time polynomial in the number of digits of
using the powering algorithm of Section 2.3.
Suppose next that
.
Unfortunately, we do not know a deterministic algorithm
that takes as input
and
, outputs
a square root of
modulo
when one exists,
and is polynomial-time in
.
Remark 4.5
There is an algorithm due to Schoof [#!schoof:sqrt!#] that computes
the square root of
data:image/s3,"s3://crabby-images/d80ba/d80baa05f15d88aa1f163be96ba12c6b68654be2" alt="$ a$"
in time
data:image/s3,"s3://crabby-images/f66e9/f66e9922f1e92847fa01ded3b16932c374d0c0b7" alt="$ O((\sqrt(\vert a\vert)^{1/2 + \varepsilon } \cdot
\log(p))^9)$"
. This beautiful algorithm (which makes use of elliptic
curves) is not polynomial time in the sense described above since
for large
data:image/s3,"s3://crabby-images/d80ba/d80baa05f15d88aa1f163be96ba12c6b68654be2" alt="$ a$"
it takes exponentially longer than for small
data:image/s3,"s3://crabby-images/d80ba/d80baa05f15d88aa1f163be96ba12c6b68654be2" alt="$ a$"
.
We next describe a probabilistic algorithm to
compute a square root of
modulo
, which is very quick
in practice.
Recall the definition of ring from Definition 2.1.3.
We will also need the notion of ring homomorphism and isomorphism.
Definition 4.5 (Homomorphism of Rings)
Let
data:image/s3,"s3://crabby-images/adb90/adb90418e48e8c031b4c5420fa401220dc1aa7eb" alt="$ R$"
and
data:image/s3,"s3://crabby-images/e0476/e0476e3ed9681edb010b4a9b23c94d6fb9c25f54" alt="$ S$"
be rings.
A
homomorphism of rings
data:image/s3,"s3://crabby-images/4eb1c/4eb1cf199d0648582ed94d90a3542b5fc5c0e1f8" alt="$ \varphi :R\to S$"
is a map such that for all
data:image/s3,"s3://crabby-images/1beb2/1beb2787cacd171e7076724c2004d8de5a138b5c" alt="$ a,b\in R$"
we have
An
isomorphism
data:image/s3,"s3://crabby-images/4eb1c/4eb1cf199d0648582ed94d90a3542b5fc5c0e1f8" alt="$ \varphi :R\to S$"
of rings is a
ring homomorphism that is bijective.
Consider the (quotient) ring
defined as follows.
We have
with multiplication defined by
Here
corresponds to the class of
in the quotient ring.
SAGE Example 4.5
We define and work with the quotient ring
data:image/s3,"s3://crabby-images/adb90/adb90418e48e8c031b4c5420fa401220dc1aa7eb" alt="$ R$"
above
in SAGE as follows (for
data:image/s3,"s3://crabby-images/7fb34/7fb349b3ba12c363f24330be6562ff9f257aa03a" alt="$ p=13$"
):
sage: S.<x> = PolynomialRing(GF(13))
sage: R.<alpha> = S.quotient(x^2 - 3)
sage: (2+3*alpha)*(1+2*alpha)
7*alpha + 7
Let
and
be the square roots of
in
(though we cannot easily
compute
and
yet, we can consider them in order
to deduce an algorithm to find them).
We have ring homomorphisms
and
given by
and
.
Together these define a ring isomorphism
given by
.
Choose in some way a random element
of
, and
define
by
where we compute
quickly
using an analogue of the
binary powering algorithm of Section 2.3.2.
If
we try again with another random
. If
we can
quickly find the desired square roots
and
as follows. The
quantity
is a
power in
, so it equals
either 0
,
, or
, so
,
, or
,
respectively. Since we know
and
we can try each of
,
, and
and see which is a square root of
.
Example 4.5
Continuing Example
4.1.8,
we find a square root of
data:image/s3,"s3://crabby-images/f3ad9/f3ad982a266ad05585734090be55e631fdb9f138" alt="$ 69$"
modulo
data:image/s3,"s3://crabby-images/b6ee9/b6ee9b4923eac37fdc338fd52b97e4b00a2f5ac8" alt="$ 389$"
.
We apply the algorithm described above in the case
data:image/s3,"s3://crabby-images/6c5f7/6c5f7d82a477369b914e53dadc3f79b6e3b83244" alt="$ p\equiv 1\pmod{4}$"
.
We first choose the random
data:image/s3,"s3://crabby-images/a9260/a92608c6237cc8a948f7e516d2c29bb194d6a6c6" alt="$ z=24$"
and find that
data:image/s3,"s3://crabby-images/e5835/e58357180570faccb999120a2e622a106fa794ff" alt="$ (1+24\alpha)^{194} = -1.
$"
The coefficient of
data:image/s3,"s3://crabby-images/19c2b/19c2beca6568e6e7172af77aa8f9904c6c4d3cb6" alt="$ \alpha$"
in the power is
0
, and we try again with
data:image/s3,"s3://crabby-images/84fad/84fad5dc46c2ae2360fc77c660f296905d235219" alt="$ z=51$"
.
This time we have
data:image/s3,"s3://crabby-images/257a0/257a0922ae1c62c93820e5c3aaff8d44ae65215b" alt="$ (1+51\alpha)^{194} = 239\alpha = u +v\alpha$"
.
The inverse of
data:image/s3,"s3://crabby-images/5aeab/5aeab43603da46f0910b53953f99738433db717c" alt="$ 239$"
in
data:image/s3,"s3://crabby-images/696bb/696bb4b6fe8bf2d05c82132d38cd1936bdae9dbf" alt="$ \mathbb{Z}/389\mathbb{Z}{}$"
is
data:image/s3,"s3://crabby-images/1cd96/1cd96850fea65bf99a8edc7acc6aad82e31136cd" alt="$ 153$"
, so we consider the
following three possibilities for a square root of
data:image/s3,"s3://crabby-images/f3ad9/f3ad982a266ad05585734090be55e631fdb9f138" alt="$ 69$"
:
Thus
data:image/s3,"s3://crabby-images/1cd96/1cd96850fea65bf99a8edc7acc6aad82e31136cd" alt="$ 153$"
and
data:image/s3,"s3://crabby-images/e4bfc/e4bfccbcc7b649c81c424adcd2953ca603b90426" alt="$ -153$"
are the square roots of
data:image/s3,"s3://crabby-images/f3ad9/f3ad982a266ad05585734090be55e631fdb9f138" alt="$ 69$"
in
data:image/s3,"s3://crabby-images/696bb/696bb4b6fe8bf2d05c82132d38cd1936bdae9dbf" alt="$ \mathbb{Z}/389\mathbb{Z}{}$"
.
SAGE Example 4.5
We implement the above algorithm in SAGE and illustrate it
with some examples.
sage: def find_sqrt(a, p):
... assert (p-1)%4 == 0
... assert legendre_symbol(a,p) == 1
... S.<x> = PolynomialRing(GF(p))
... R.<alpha> = S.quotient(x^2 - a)
... while True:
... z = GF(p).random_element()
... w = (1 + z*alpha)^((p-1)//2)
... (u, v) = (w[0], w[1])
... if v != 0: break
... if (-u/v)^2 == a: return -u/v
... if ((1-u)/v)^2 == a: return (1-u)/v
... if ((-1-u)/v)^2 == a: return (-1-u)/v
...
sage: b = find_sqrt(3,13)
sage: b # random: either 9 or 3
9
sage: b^2
3
sage: b = find_sqrt(3,13)
sage: b # see, it's random
4
sage: find_sqrt(5,389) # random: either 303 or 86
303
sage: find_sqrt(5,389) # see, it's random
86
William
2007-06-01