12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- from openfhe import *
- import time
- def main():
- print("\n======EXAMPLE FOR EVALPOLY========\n")
- parameters = CCParamsCKKSRNS()
- parameters.SetMultiplicativeDepth(6)
- parameters.SetScalingModSize(50)
- cc = GenCryptoContext(parameters)
- cc.Enable(PKESchemeFeature.PKE)
- cc.Enable(PKESchemeFeature.KEYSWITCH)
- cc.Enable(PKESchemeFeature.LEVELEDSHE)
- cc.Enable(PKESchemeFeature.ADVANCEDSHE)
- input = [complex(a,0) for a in [0.5, 0.7, 0.9, 0.95, 0.93]]
-
- encoded_length = len(input)
- coefficients1 = [0.15, 0.75, 0, 1.25, 0, 0, 1, 0, 1, 2, 0, 1, 0, 0, 0, 0, 1]
- coefficients2 = [1, 2, 3, 4, 5, -1, -2, -3, -4, -5,
- 0.1, 0.2, 0.3, 0.4, 0.5, -0.1, -0.2, -0.3, -0.4, -0.5,
- 0.1, 0.2, 0.3, 0.4, 0.5, -0.1, -0.2, -0.3, -0.4, -0.5]
- plaintext1 = cc.MakeCKKSPackedPlaintext(input)
- key_pair = cc.KeyGen()
-
- print("Generating evaluation key for homomorphic multiplication...")
- cc.EvalMultKeyGen(key_pair.secretKey)
- print("Completed.\n")
- ciphertext1 = cc.Encrypt(key_pair.publicKey, plaintext1)
- t = time.time()
- result = cc.EvalPoly(ciphertext1, coefficients1)
- time_eval_poly1 = time.time() - t
- t = time.time()
- result2 = cc.EvalPoly(ciphertext1, coefficients2)
- time_eval_poly2 = time.time() - t
- plaintext_dec = cc.Decrypt(result, key_pair.secretKey)
- plaintext_dec.SetLength(encoded_length)
- plaintext_dec2 = cc.Decrypt(result2, key_pair.secretKey)
- plaintext_dec2.SetLength(encoded_length)
- print("\n Original Plaintext #1: \n")
- print(plaintext1)
- print(f"\n Result of evaluating a polynomial with coefficients {coefficients1}: \n")
- print(plaintext_dec)
- print("\n Expected result: (0.70519107, 1.38285078, 3.97211180, "
- "5.60215665, 4.86357575) \n")
- print(f"\n Evaluation time: {time_eval_poly1*1000} ms \n")
- print(f"\n Result of evaluating a polynomial with coefficients {coefficients2}: \n")
- print(plaintext_dec2)
- print("\n Expected result: (3.4515092326, 5.3752765397, 4.8993108833, "
- "3.2495023573, 4.0485229982) \n")
- print(f"\n Evaluation time: {time_eval_poly2*1000} ms \n")
- if __name__ == '__main__':
- main()
|