Skip to content

Commit

Permalink
feat: Add examples for KZG commiment
Browse files Browse the repository at this point in the history
  • Loading branch information
VanhGer committed Jul 22, 2024
1 parent c6d2ee1 commit d1989bc
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 7 deletions.
4 changes: 4 additions & 0 deletions kzg/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,10 @@ version = "0.1.0"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[[example]]
name = "kzg-example"
path = "examples/example.rs"


[dependencies]
ark-ff = "0.4.2"
Expand Down
26 changes: 26 additions & 0 deletions kzg/examples/example.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
use ark_bls12_381::Fr;
use ark_poly::univariate::DensePolynomial;
use ark_poly::{DenseUVPolynomial, Polynomial};
use kzg::scheme::KzgScheme;
use kzg::srs::Srs;

fn main() {
// trusted setup
let srs = Srs::new(10);
let scheme = KzgScheme::new(srs);

// polynomial x^3 + 3x + 5

let coeff = vec![Fr::from(5), Fr::from(3), Fr::from(0), Fr::from(1)];
let poly = DensePolynomial::from_coefficients_vec(coeff);
let v = poly.evaluate(&Fr::from(1));
assert_eq!(v, Fr::from(9));

// commit poly
let commitment = scheme.commit(&poly);
// opening point at p = 4.
let opening_pos = Fr::from(4);
let opening = scheme.open(&poly, opening_pos);

assert!(scheme.verify(&commitment, &opening, opening_pos));
}
4 changes: 2 additions & 2 deletions kzg/src/commitment.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ mod tests {
.mul(poly.evaluate(&secret))
.into_affine()
);
let opening = scheme.open(poly, d);
let opening = scheme.open(&poly, d);
assert!(scheme.verify(&commitment, &opening, d));
}

Expand Down Expand Up @@ -111,7 +111,7 @@ mod tests {
let openings: Vec<KzgOpening> = f
.iter()
.zip(z)
.map(|(f_i, z_i)| scheme.open(f_i.clone(), z_i))
.map(|(f_i, z_i)| scheme.open(f_i, z_i))
.collect();
let c: Vec<KzgCommitment> = f.iter().map(|f_i| scheme.commit(f_i)).collect();
let mut rng = StdRng::from_entropy();
Expand Down
3 changes: 2 additions & 1 deletion kzg/src/opening.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@ use crate::types::G1Point;

/// Represents an opening at a point with its corresponding evaluation.
///
/// `KzgOpening` encapsulates a `G1Point` representing the point and an `Fr` representing the evaluation.
/// `KzgOpening` encapsulates a `G1Point` representing the corresponding point
/// of quotient polynomial and an `Fr` representing the evaluation.
#[derive(Debug, Clone)]
pub struct KzgOpening(pub G1Point, pub Fr);

Expand Down
12 changes: 8 additions & 4 deletions kzg/src/scheme.rs
Original file line number Diff line number Diff line change
Expand Up @@ -89,14 +89,16 @@ impl KzgScheme {
/// # Returns
///
/// The opening at the specified point.
pub fn open(&self, mut polynomial: Poly, z: impl Into<Fr>) -> KzgOpening {
pub fn open(&self, polynomial: &Poly, z: impl Into<Fr>) -> KzgOpening {
let z = z.into();
let evaluation_at_z = polynomial.evaluate(&z);
let first = polynomial.coeffs.first_mut().expect("at least 1");
let mut new_poly = polynomial.clone();
let first = new_poly.coeffs.first_mut().expect("at least 1");
*first -= evaluation_at_z;
let root = Poly::from_coefficients_slice(&[-z, 1.into()]);
let new_poly = &polynomial / &root;
let opening = self.evaluate_in_s(&new_poly);
// quotient polynomial
let quotient_poly = &new_poly / &root;
let opening = self.evaluate_in_s(&quotient_poly);

KzgOpening(opening, evaluation_at_z)
}
Expand All @@ -123,7 +125,9 @@ impl KzgScheme {
let g2 = self.0.g2();
let a = g2s.sub(g2.mul(z.into()).into_affine());
let b = commitment.0.sub(G1Point::generator().mul(y).into_affine());
// e([Q]_1, [x]_2 - G_2 ⋅ z)
let pairing1 = Bls12_381::pairing(opening.0, a);
// e([P]_1 - G_1 ⋅ P(x), G_2)
let pairing2 = Bls12_381::pairing(b, g2);
pairing1 == pairing2
}
Expand Down

0 comments on commit d1989bc

Please sign in to comment.