« previous | Tuesday, March 5, 2013 | next »
Midterm
Midterm Thursday after Spring Break
Material is anything up to today.
Practice midterm available on web page
Review
- Powering mod
is easy but slow.
- Computing square roots mod prime
is easy-ish
- Computing square roots mod any integer
is hard: in fact, deciding whether
is NP-Complete
- Deciding existence of square roots mod
can be done by powering, but is faster via quadratic reciprocity of Jacobi symbols
- Factoring appears hard, but is easy if computing square roots mod
is easy.
El Gamal
- Large prime
, with
having at least one huge prime factor
- Generator
for data:image/s3,"s3://crabby-images/462f3/462f3a81916fbb1ddcec9dd8afe25106f48ca776" alt="{\displaystyle \left(\mathbb {Z} /p\mathbb {Z} \right)^{*}}"
- Number
![{\displaystyle a\in [2,2]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/a83ff6347b810ea554f7569ea02a6bbc590a64c4)
data:image/s3,"s3://crabby-images/1f3cf/1f3cf74d0b3bb5288a8067022b9ff27236cc59f2" alt="{\displaystyle \beta =\alpha ^{a}{\pmod {p}}}"
are public, recipient holds
secret.
to transmit a message
, the sender computes a random
,
, and
; and then sends
To decode, the recipient computes
Questions:
- How does this hide
? (
appears random, and multiplication by it scrambles
)
- why does decryption work?
data:image/s3,"s3://crabby-images/b3d80/b3d803b1427895321fd15c5d7d5b46773136c727" alt="{\displaystyle {\frac {\beta ^{k}\,m}{(\alpha ^{k})^{a}}}={\frac {\beta ^{k}\,m}{(\alpha ^{a})^{k}}}={\frac {\beta ^{k}\,m}{\beta ^{k}}}=m{\pmod {p}}}"
Crypytanalysis
Most obvious: find
.
Finding
involves solving
for
. This involves solving the discrete log problem, which is appears to be hard
Example
data:image/s3,"s3://crabby-images/58878/588783e118e18f44e36caf1c14d5c43f28e5194d" alt="{\displaystyle p=1009}"
(i.e.
)
data:image/s3,"s3://crabby-images/82663/826632dd38e554389c20f0d47e409ac7bb01fdef" alt="{\displaystyle m=559}"
- pick
at random and transmit data:image/s3,"s3://crabby-images/4b103/4b1031545ce0ae6c143e82e65fc39ed23f981a16" alt="{\displaystyle (\alpha ^{k},\beta ^{k}\,m)=(421,661)}"
Pohlig-Hellman
Recall:
- If
is a square mod
, then
.
- If
is a non-square mod
, then
.
So if
, we see that
- when
is even, then data:image/s3,"s3://crabby-images/1fd35/1fd35f21d5fb9d0407de30909a695e9890a7d8a7" alt="{\displaystyle \beta ^{\frac {p-1}{2}}\equiv 1{\pmod {p}}}"
- when
is odd, then data:image/s3,"s3://crabby-images/9bc77/9bc77f82697f948a629ae545fc3bcc9644d9cea9" alt="{\displaystyle \beta ^{\frac {p-1}{2}}\equiv -1{\pmod {p}}}"
That is, you can tell the parity of
(the last base-2 digit).
Example
,
,
, and
Notice that
. This would be a bad choice.
Note: Fermat primes are of the form data:image/s3,"s3://crabby-images/97291/972916670c2ae022e28395e0d9e053f7a87ac16f" alt="{\displaystyle 2^{n}+1}"
We want to find
with
. Is
odd or even? (check Legendre symbol)
So
is even and
.
Now we want to find
Where
is the last digit mod 3.
We find
, so
must be 0.
So
Now we want to find
, and by brute force,
.
So
Yada yada,
The Chinese Remainder Theorem states that we have a unique
such that it is equivalent to (0,0,2,6) mod (2,3,5,7), respectively.
- Combine
and
to get data:image/s3,"s3://crabby-images/b6f99/b6f99533e71284aeff9b8cdb5e2e6eacb6bbff86" alt="{\displaystyle a\equiv 0{\pmod {6}}}"
- Combine that with
to get data:image/s3,"s3://crabby-images/d6563/d65633dfc70ea616cb4c6a3a243aaa6b24e3360d" alt="{\displaystyle a\equiv 6{\pmod {42}}}"
- Combine that with
to get
.
And indeed,
, and
Note: Pohlig Hellman also handles base data:image/s3,"s3://crabby-images/77007/7700774bfc09e01233ae72a92de9abd57b28311f" alt="{\displaystyle q^{k}}"