main.cpp 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include <iostream>
  2. #include "BGN.hpp"
  3. int main(void)
  4. {
  5. BGN system;
  6. Scalar test3(3);
  7. Scalar test5(5);
  8. Scalar decrypted3, decrypted5, decrypted6, decrypted10, decrypted15, decrypted30;
  9. std::cout << "Scalar test value (3): " << test3 << std::endl;
  10. std::cout << "Scalar test value (5): " << test5 << std::endl;
  11. CurveBipoint encrypted3, encrypted6;
  12. TwistBipoint encrypted5, encrypted10;
  13. Quadripoint encrypted15, encrypted30;
  14. std::cout << "Performing encryptions" << std::endl;
  15. system.encrypt(encrypted3, test3);
  16. system.encrypt(encrypted5, test5);
  17. std::cout << "Performing additions" << std::endl;
  18. encrypted6 = system.homomorphic_addition(encrypted3, encrypted3);
  19. encrypted10 = system.homomorphic_addition(encrypted5, encrypted5);
  20. std::cout << "Performing multiplication" << std::endl;
  21. encrypted15 = system.homomorphic_multiplication(encrypted3, encrypted5);
  22. std::cout << "Performing L2 addition" << std::endl;
  23. encrypted30 = system.homomorphic_addition(encrypted15, encrypted15);
  24. std::cout << "Performing decryptions" << std::endl;
  25. decrypted3 = system.decrypt(encrypted3);
  26. std::cout << "Scalar decrypted value (3): " << decrypted3 << std::endl;
  27. decrypted5 = system.decrypt(encrypted5);
  28. std::cout << "Scalar decrypted value (5): " << decrypted5 << std::endl;
  29. decrypted6 = system.decrypt(encrypted6);
  30. std::cout << "Scalar decrypted value (6): " << decrypted6 << std::endl;
  31. decrypted10 = system.decrypt(encrypted10);
  32. std::cout << "Scalar decrypted value (10): " << decrypted10 << std::endl;
  33. decrypted15 = system.decrypt(encrypted15);
  34. std::cout << "Scalar decrypted value (15): " << decrypted15 << std::endl;
  35. decrypted30 = system.decrypt(encrypted30);
  36. std::cout << "Scalar decrypted value (30): " << decrypted30 << std::endl;
  37. return 0;
  38. }