notequals.rs 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. #![allow(non_snake_case)]
  2. use curve25519_dalek::ristretto::RistrettoPoint as G;
  3. use group::ff::PrimeField;
  4. use group::Group;
  5. use sha2::Sha512;
  6. use sigma_compiler::*;
  7. fn do_test(x_u128: u128) -> sigma_proofs::errors::Result<()> {
  8. sigma_compiler! { proof,
  9. (x, rand r),
  10. (C, const cind A, const cind B),
  11. C = (3*x+1)*A + r*B,
  12. 2*x-5 != 1,
  13. }
  14. type Scalar = <G as Group>::Scalar;
  15. let mut rng = rand::thread_rng();
  16. let A = G::hash_from_bytes::<Sha512>(b"Generator A");
  17. let B = G::generator();
  18. let r = Scalar::random(&mut rng);
  19. let x = Scalar::from_u128(x_u128);
  20. let C = (Scalar::from_u128(3) * x + Scalar::ONE) * A + r * B;
  21. let instance = proof::Instance { C, A, B };
  22. let witness = proof::Witness { x, r };
  23. let proof = proof::prove(&instance, &witness, b"notequals_test", &mut rng)?;
  24. proof::verify(&instance, &proof, b"notequals_test")
  25. }
  26. #[test]
  27. fn notequals_test() {
  28. do_test(0).unwrap();
  29. do_test(1).unwrap();
  30. do_test(2).unwrap();
  31. do_test(4).unwrap();
  32. do_test(5).unwrap();
  33. }
  34. #[test]
  35. #[should_panic]
  36. fn notequals_fail_test() {
  37. do_test(3).unwrap();
  38. }