Skip to content

Commit

Permalink
Merge pull request zcash#502 from zcash/simplify-ipa-equation
Browse files Browse the repository at this point in the history
halo2_proofs: change IPA check equation to match the book
  • Loading branch information
ebfull authored Feb 14, 2022
2 parents 8c0deb1 + 0b73c74 commit 247cd62
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 15 deletions.
4 changes: 4 additions & 0 deletions halo2_proofs/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,10 @@ and this project adheres to Rust's notion of
- `halo2_proofs::dev::FailureLocation` (used in `VerifyFailure::Lookup`)

### Changed
- `halo2_proofs::commitment::verifier::Guard`, which is returned from
`halo2_proofs::plonk::verify_proof`, has changed so that values
returned from its method `compute_g` and expected in its method `use_g`
are not backwards compatible with values in previous versions.
- `halo2_proofs::plonk::verify_proof` now takes a `VerificationStrategy` instead
of an `MSM` directly.
- `halo2_proofs` now depends on `rand_core` instead of `rand`.
Expand Down
21 changes: 6 additions & 15 deletions halo2_proofs/src/poly/commitment/verifier.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,13 +35,12 @@ impl<'a, C: CurveAffine, E: EncodedChallenge<C>> Guard<'a, C, E> {
pub fn use_challenges(mut self) -> MSM<'a, C> {
let s = compute_s(&self.u, self.neg_c);
self.msm.add_to_g_scalars(&s);
self.msm.add_to_w_scalar(self.neg_c);

self.msm
}

/// Lets caller supply the purported G point and simply appends
/// [-a] G to return an updated MSM.
/// [-c] G to return an updated MSM.
pub fn use_g(mut self, g: C) -> (MSM<'a, C>, Accumulator<C, E>) {
self.msm.append_term(self.neg_c, g);

Expand All @@ -53,13 +52,11 @@ impl<'a, C: CurveAffine, E: EncodedChallenge<C>> Guard<'a, C, E> {
(self.msm, accumulator)
}

/// Computes G + W, where G = ⟨s, params.g⟩ and W is used for blinding
/// Computes G = ⟨s, params.g⟩
pub fn compute_g(&self) -> C {
let s = compute_s(&self.u, C::Scalar::one());

let mut tmp = best_multiexp(&s, &self.msm.params.g);
tmp += self.msm.params.w;
tmp.to_affine()
best_multiexp(&s, &self.msm.params.g).to_affine()
}
}

Expand Down Expand Up @@ -118,15 +115,9 @@ pub fn verify_proof<'a, C: CurveAffine, E: EncodedChallenge<C>, T: TranscriptRea
// equals (given b = \mathbf{b}_0, and the prover's values c, f),
// the right-hand side
// = [c] (G'_0 + [b * z] U) + [f] W
// except that we wish for the prover to supply G'_0 as Commit(g(X); 1) so
// we must substitute G'_0 with G'_0 - W to get
// = [c] ((G'_0 - W) + [b * z] U) + [f] W
// = [c] G'_0 + [-c] W + [cbz] U + [f] W
// = [c] G'_0 + [cbz] U + [f - c] W
// and then subtracting the right-hand side from both sides
// to get
// Subtracting the right-hand side from both sides we get
// P' + \sum([u_j^{-1}] L_j) + \sum([u_j] R_j)
// + [-c] G'_0 + [-cbz] U + [c - f] W
// + [-c] G'_0 + [-cbz] U + [-f] W
// = 0

let c = transcript.read_scalar().map_err(|_| Error::SamplingError)?;
Expand All @@ -135,7 +126,7 @@ pub fn verify_proof<'a, C: CurveAffine, E: EncodedChallenge<C>, T: TranscriptRea
let b = compute_b(x, &u);

msm.add_to_u_scalar(neg_c * &b * &z);
msm.add_to_w_scalar(c - &f);
msm.add_to_w_scalar(-f);

let guard = Guard {
msm,
Expand Down

0 comments on commit 247cd62

Please sign in to comment.