Skip to content

Commit

Permalink
plonk: proof-system: proof-linking: Impl serialization for LinkingProof
Browse files Browse the repository at this point in the history
  • Loading branch information
joeykraut committed Jan 12, 2024
1 parent 0ce6a9c commit deee144
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 4 deletions.
1 change: 1 addition & 0 deletions plonk/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ ark-ed-on-bn254 = "0.4.0"
criterion = { version = "0.5", features = ["async", "async_tokio"] }
hex = "^0.4.3"
lazy_static = "1.4"
serde_json = "1.0"
tokio = "1.33"

# Benchmarks
Expand Down
53 changes: 49 additions & 4 deletions plonk/src/proof_system/proof_linking.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ use ark_ec::{
};
use ark_ff::{Field, One, Zero};
use ark_poly::{univariate::DensePolynomial, DenseUVPolynomial};
use ark_serialize::{CanonicalDeserialize, CanonicalSerialize};
use jf_primitives::{
pcs::{
prelude::{Commitment, UnivariateKzgPCS, UnivariateKzgProof},
Expand All @@ -19,6 +20,7 @@ use mpc_relation::{
gadgets::ecc::SWToTEConParam,
proof_linking::{GroupLayout, PROOF_LINK_WIRE_IDX},
};
use serde::{Deserialize, Serialize};

use crate::{errors::PlonkError, transcript::PlonkTranscript};

Expand All @@ -28,14 +30,36 @@ use super::{
};

/// A proof that two circuits are linked on a given domain
#[derive(Clone, Debug)]
#[derive(Clone, Debug, PartialEq, Eq, CanonicalSerialize, CanonicalDeserialize)]
pub struct LinkingProof<E: Pairing> {
/// The commitment to the linking quotient polynomial
pub quotient_commitment: Commitment<E>,
/// The proof of opening of the linking identity polynomial
pub opening_proof: UnivariateKzgProof<E>,
}

impl<E: Pairing> Serialize for LinkingProof<E> {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
let mut bytes = Vec::new();
self.serialize_compressed(&mut bytes).map_err(serde::ser::Error::custom)?;

serializer.serialize_bytes(&bytes)
}
}

impl<'de, E: Pairing> Deserialize<'de> for LinkingProof<E> {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::Deserializer<'de>,
{
let bytes = <Vec<u8>>::deserialize(deserializer)?;
Self::deserialize_compressed(bytes.as_slice()).map_err(serde::de::Error::custom)
}
}

// ----------
// | Prover |
// ----------
Expand Down Expand Up @@ -407,8 +431,10 @@ pub mod test_helpers {
#[cfg(test)]
mod test {
use ark_bn254::{Bn254, Fr as FrBn254};
use ark_ec::pairing::Pairing;
use ark_std::UniformRand;
use itertools::Itertools;
use jf_primitives::pcs::prelude::UnivariateKzgProof;
use mpc_relation::{
proof_linking::{GroupLayout, LinkableCircuit},
PlonkCircuit,
Expand All @@ -424,9 +450,12 @@ mod test {
transcript::SolidityTranscript,
};

use super::test_helpers::{
gen_commit_keys, gen_proving_keys, gen_test_circuit1, gen_test_circuit2, CircuitSelector,
GROUP_NAME,
use super::{
test_helpers::{
gen_commit_keys, gen_proving_keys, gen_test_circuit1, gen_test_circuit2,
CircuitSelector, GROUP_NAME,
},
LinkingProof,
};

// -----------
Expand Down Expand Up @@ -493,6 +522,22 @@ mod test {
// | Test Cases |
// --------------

/// Tests serialization and deserialization of a linking proof
#[test]
fn test_serde() {
let mut rng = thread_rng();
let commitment = <Bn254 as Pairing>::G1Affine::rand(&mut rng).into();
let opening = UnivariateKzgProof { proof: <Bn254 as Pairing>::G1Affine::rand(&mut rng) };

let proof =
LinkingProof::<Bn254> { quotient_commitment: commitment, opening_proof: opening };

let bytes = serde_json::to_vec(&proof).unwrap();
let recovered = serde_json::from_slice(&bytes).unwrap();

assert_eq!(proof, recovered);
}

/// Tests a linking proof between two circuits that correctly use the same
/// values in the linking domain
#[test]
Expand Down

0 comments on commit deee144

Please sign in to comment.