« previous | Thursday, February 7, 2013 | next »
Midterm Exam on Thursday, March 21, 2013
Recursive Squaring
What is
?
Note that 818 = 512 + 256 + 32 + 16 + 2, so we can compute:
data:image/s3,"s3://crabby-images/6f780/6f780db2f3567c4a9a6d33c0e102c623341cae35" alt="{\displaystyle 7^{2}\equiv 49{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/9a101/9a101d8e7591cc4bd38a6fb4281bc2a98b4443f0" alt="{\displaystyle 7^{4}\equiv 49^{2}\equiv 764{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/0af69/0af69189db5a148591e2f8cbb47439437695745c" alt="{\displaystyle 7^{8}\equiv 764^{2}\equiv 924{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/5943f/5943fca53ace14d1694d3f00ba3c2379edd82cbf" alt="{\displaystyle 7^{16}\equiv 924^{2}\equiv 899{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/b4a72/b4a7283919e541d10e01fc6102d40d7e13f35e2a" alt="{\displaystyle 7^{32}\equiv 899^{2}\equiv 1160{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/f389e/f389ec8a03f7a2cd7d22154e78c77ae5de8b8855" alt="{\displaystyle 7^{64}\equiv 1160^{2}\equiv 1623{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/1c508/1c50806561543fffe872418f8d1a64c9ce45f643" alt="{\displaystyle 7^{128}\equiv 1623^{2}\equiv 196{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/4f28d/4f28dfec114d6d5acd157a78e6d2d640ebf78a68" alt="{\displaystyle 7^{256}\equiv 196^{2}\equiv 765{\pmod {1637}}}"
data:image/s3,"s3://crabby-images/57f23/57f232ced05ba7fd1ad44a3d59b50a96644f873c" alt="{\displaystyle 7^{512}\equiv 765^{2}\equiv 816{\pmod {1637}}}"
We poerformed a total of 13 multiplications!
Legendre Symbol
Euler's Criterion
Euler's [1] Criterion:
If
and
is an odd prime, then
Proof
First, if
, then
and thus
. Indeed
.
Assume
, then it's enough to show
If
then
for some
. So
by Fermat's little theorem.
Conversely, using the theorem below, let
for some
and generator
. Now
data:image/s3,"s3://crabby-images/b6e89/b6e89ffb7f3f86975aaaad98972421a5ea09af98" alt="{\displaystyle a^{\frac {p-1}{2}}\equiv \left(g^{k}\right)^{\frac {p-1}{2}}\equiv g^{\frac {k(p-1)}{2}}\equiv 1{\pmod {p}}}"
Since
is a generator, any power of
must have exponent divisible by
. So
implies that
is divisible by 2. Therefore,
is a square.
Q.E.D.
Theorem
For any prime
,
as a multiplicative generator (primitive root), that is, there is a
with
In sage, you can say
sage: R = Integers(13)
to use
sage: R.multiplicative_generator()
2
So
Why do we care about modular square roots?
Suppose you had a magic machine that quickly computed square roots mod any integer. Then you can break RSA!
To break RSA, you need one of: luck, treachery, knowing either
or
and
or
's factorization.
If you know how to compute square roots mod
, factoring
is easy
Example
Let
.
Pick a random number, e.g. 4
Let's "magically" compute
:
Consider
and
.
- GCD(988027, 4) = 1
- GCD(988027, 0) = 988027
Pick another random number, e.g. 42
There are 4 square roots to 42 mod 98027: 323739, 429421, 558606, and 664288.
- GCD(323739-429421, 988027) = 997
- GCD(323739+429421, 988027) = ...
Thus 997 divides 988027. In particular,
GCD's are relatively easy to compute. Therefore, if we can take square roots quickly, we can factor quickly
In General
Assuming you can find square roots mod
quickly, you can factor as follows:
Input: integer N of form N = p*q, where p and q are large odd primes
Output: p and q
Description:
(1) Pick random k in {1, ..., N-1}
(2) Decide if sqrt(k) mod N exists.
If not, go to step 1.
(3) Find 2 distinct square roots of k mod N.
Call them X1 and X2.
(4) If GCD(X1-X2, N) > 1 or GCD(X1+X2, N) > 1, then that number is p or q.
Divide by it to get q or p
(5) Go to step 1
Theorem: If you can compute square roots mod
for the kinds of
just stated in time
, then you can factor
in expected time
via our last algorithm.
This theorem is modern, but the ideas go back to Gauss (1777–1855)
Proof will come later.
A consequence of Euler's Criterion:
Corollary
If
is an odd prime with
and
, then the square roots of
are exactly
Proof. If
, then (by Euler),
Now
, so
So
Now
So