Difference between revisions of "GSW - Bootstrapping"
Line 13: | Line 13: | ||
Given a modulus <math>q </math>, let us denote by <math> l = \lceil \log_2(q) \rceil </math> and define the "gadget" (we will think of it as column) vector | Given a modulus <math>q </math>, let us denote by <math> l = \lceil \log_2(q) \rceil </math> and define the "gadget" (we will think of it as column) vector | ||
<center> <math> \mathfrak g = (1,2,4, \dots, 2^{l-1}) \in \mathbb Z_q^l. </math> </center> | <center> <math> \mathfrak g = (1,2,4, \dots, 2^{l-1}) \in \mathbb Z_q^l. </math> </center> | ||
− | Remark that <math> 2^{l-2} \in [q/4,1/2) \ | + | Remark that <math> 2^{l-2} \in [q/4,1/2) \pmod{q}</math>, according to our choice of <math>l</math>. |
== References == | == References == |
Revision as of 11:15, 12 June 2020
Gentry's bootstrapping theorem allows for converting a “somewhat homomorphic” encryption scheme (which supports only a bounded number of homomorphic operations) into a fully homomorphic encryption one (which has no such bound). The bounded nature of all known somewhat homomorphic schemes cannot be avoided due to “error” terms in their ciphertexts, which are necessary for security. The error grows as a result of performing homomorphic operations, and if it grows too large, the ciphertext will no longer decrypt correctly.
Bootstrapping the error of a ciphertext so that it can support more homomorphic operations, by homomorphically evaluating the decryption function on the ciphertext. The result is a ciphertext that still encrypts the original encrypted message. If the error coming from the homomorphic evaluation is smaller than the error in the original ciphertext, we say that the ciphertext is “refreshed”. To date, bootstrapping is the only known way of obtaining an unbounded FHE scheme, i.e., one that can homomorphically evaluate any efficient function using keys and ciphertexts of a fixed size.
Here we present an efficient bootstrapping method for a variant of the GSW scheme, as presented in the paper of Alperin-Sheriff and Peikert [1].
A "simpler" variant of the GSW cryptosystem
The authors present a variant of the GSW scheme which permits a tighter analysis of its error growth under homomorphic operations.
Given a modulus , let us denote by and define the "gadget" (we will think of it as column) vector
Remark that , according to our choice of .
References
- ↑ J. Alperin-Sheriff and C. Peikert. Faster Bootstrapping with Polynomial Error. In CRYPTO 2014 (Springer). https://eprint.iacr.org/2014/094