« previous | Tuesday, March 26, 2013 | next »
Secret Sharing
A
-threshhold scheme is a way to share a message among
participants so that any subset of
participants can recover the message, but no smaller subset.
Small example: (2,2)-threshhold schemes have been in various movies involving nuclear missiles (e.g. War Games)
Another example: (3,55)-threshhold scheme could protect the password to some chocolate
In 1979, Adi Shamir found following scheme to hide a message
- Pick a prime
data:image/s3,"s3://crabby-images/764c2/764c2c25f8f0ee54294da34963a5fe15d9b8bad0" alt="{\displaystyle p\geq \max {(W,M)}}"
- Pick
random numbers
in data:image/s3,"s3://crabby-images/1f485/1f48510535473cf0e71c3c48e2741cf1ba337d93" alt="{\displaystyle \mathbb {Z} /p\mathbb {Z} }"
- Define
data:image/s3,"s3://crabby-images/33997/33997e1579a8f4b08db450c1c5901864d424548a" alt="{\displaystyle p(x)=M+s_{1}\,x+\dots +s_{T-1}\,x^{T-1}}"
- Pick distinct random numbers
, and to the
th participant, give data:image/s3,"s3://crabby-images/30bda/30bda55bb2f5fae38d789920e3bdca3793f376b4" alt="{\displaystyle (x_{i},p(x_{i}))}"
Idea:
points in Euclidean space define a unique
-degree polynomial curve.
Lemmas
- No subset of
participants can recover
.
- Any subset of
participants can recover
.
Proof. Take, say, the first
participants
. We get
Which is a
linear system of equations, so we can solve
Claim: The preceding matrix has a nonzero determinant and thus we have a unique solution!
This matrix is a van Der Monde matrix.
Back to ChOcOlAtE
So we need to solve
For
and
, we get
Digital Signatures
In our Iran/UN example, we used the RSA digital signature. We also have El-Gamal and DSA (which is still used today).
If Alice needs to sign a message
,
- Alice sets up as in RSA
and publishes
and keeps
private.
- The signature
is published
Any user can verify the signature via
Note: In practice, digital signatures are slow, so usually, only a short digest of the message is signed. This is one setting where hash functions enter.
El Gamal
To sign a message
- Alice sets up as in El Gamal
and picks a random data:image/s3,"s3://crabby-images/1fbe2/1fbe28991417cf23bef6cd9b7ae0dfdddee39984" alt="{\displaystyle k\in \left(\mathbb {Z} /(p-1)\mathbb {Z} \right)^{*}}"
- Alice computes
and
data:image/s3,"s3://crabby-images/708c3/708c3801ecd77bd3fca6fcd741df8fe3270036ec" alt="{\displaystyle s=k^{-1}\left(M-a\,r\right){\pmod {p-1}}}"
- Alice sends
data:image/s3,"s3://crabby-images/389a2/389a213a908986e5e9ddbbcbe2a057c9aec6b8a0" alt="{\displaystyle (M,r,s)}"
To verify, the user must:
- download the public part
and then
- Accept if
.
Verification works because
DSA
Adopmed by NIST in 1994
- Alice finds a 160-bit prime
and a larger prime
with data:image/s3,"s3://crabby-images/cd99e/cd99efcd6486c6b5f96923b6aab19fc2f8c50edb" alt="{\displaystyle q\mid (p-1)}"
- Alice picks a primitive root
mod
and sets data:image/s3,"s3://crabby-images/21ccf/21ccf7b26f95be1d4017617006fa3fd6015dc97b" alt="{\displaystyle \alpha =g^{\frac {p-1}{q}}{\pmod {p}}}"
- Alice picks a secret
and calculates data:image/s3,"s3://crabby-images/c7a18/c7a183997ef32889fed378486a535684ed84932b" alt="{\displaystyle \beta =\alpha ^{a}}"
- Pick random
data:image/s3,"s3://crabby-images/92d83/92d83143dd1cb7e88f9eb74683490278897b0b79" alt="{\displaystyle k\in \left\{1,\ldots ,q-2\right\}}"
- Compute
data:image/s3,"s3://crabby-images/fbf15/fbf15cdb16c94345160726546e304280d1d7c826" alt="{\displaystyle r=\left(\alpha ^{k}{\pmod {p}}\right){\pmod {q}}}"
- Compute
data:image/s3,"s3://crabby-images/33872/33872cd0c0c13976e62513c990eee24e9a6af24f" alt="{\displaystyle s=k^{-1}(m+ar){\pmod {q}}}"
- Signature is
data:image/s3,"s3://crabby-images/5501e/5501e04d25d68ed156b5ec8376fecfd91cc6d0ad" alt="{\displaystyle (r,s)}"
To check signature,
- compute
and data:image/s3,"s3://crabby-images/e7f77/e7f776a786fd9b248aa813b945fc7323bebfebe5" alt="{\displaystyle u_{2}=s^{-1}\,r{\pmod {q}}}"
- Accept signature iff
data:image/s3,"s3://crabby-images/7caa6/7caa66406ea49f8f012888cf07801ad691dead85" alt="{\displaystyle \left(\alpha ^{u_{1}}\,\beta ^{u_{2}}{\pmod {p}}\right)\equiv r{\pmod {q}}}"