diff --git a/.gitignore b/.gitignore index 089ab2a1..d3067b1d 100644 --- a/.gitignore +++ b/.gitignore @@ -15,3 +15,4 @@ examples/*.sol examples/*.calldata examples/*.inputs *.serialized +*/*.serialized diff --git a/examples/circom_full_flow.rs b/examples/circom_full_flow.rs index 554ecd7b..dccf0d8e 100644 --- a/examples/circom_full_flow.rs +++ b/examples/circom_full_flow.rs @@ -89,7 +89,8 @@ fn main() { let mut nova = N::init(&nova_params, f_circuit.clone(), z_0).unwrap(); // prepare the Decider prover & verifier params - let (decider_pp, decider_vp) = D::preprocess(&mut rng, nova_params, nova.clone()).unwrap(); + let (decider_pp, decider_vp) = + D::preprocess(&mut rng, nova_params.clone(), nova.clone()).unwrap(); // run n steps of the folding iteration for (i, external_inputs_at_step) in external_inputs.iter().enumerate() { diff --git a/examples/external_inputs.rs b/examples/external_inputs.rs index a55982df..f4a6af1f 100644 --- a/examples/external_inputs.rs +++ b/examples/external_inputs.rs @@ -207,10 +207,8 @@ fn main() { folding_scheme.state() ); - let (running_instance, incoming_instance, cyclefold_instance) = folding_scheme.instances(); - println!("Run the Nova's IVC verifier"); - let ivc_proof = nova.ivc_proof(); + let ivc_proof = folding_scheme.ivc_proof(); N::verify( nova_params.1, // Nova's verifier params ivc_proof, diff --git a/examples/multi_inputs.rs b/examples/multi_inputs.rs index 9517f2ad..a337c894 100644 --- a/examples/multi_inputs.rs +++ b/examples/multi_inputs.rs @@ -154,10 +154,8 @@ fn main() { println!("Nova::prove_step {}: {:?}", i, start.elapsed()); } - let (running_instance, incoming_instance, cyclefold_instance) = folding_scheme.instances(); - println!("Run the Nova's IVC verifier"); - let ivc_proof = nova.ivc_proof(); + let ivc_proof = folding_scheme.ivc_proof(); N::verify( nova_params.1, // Nova's verifier params ivc_proof, diff --git a/examples/noir_full_flow.rs b/examples/noir_full_flow.rs index a4c7c894..64531098 100644 --- a/examples/noir_full_flow.rs +++ b/examples/noir_full_flow.rs @@ -79,7 +79,8 @@ fn main() { let mut nova = N::init(&nova_params, f_circuit.clone(), z_0).unwrap(); // prepare the Decider prover & verifier params - let (decider_pp, decider_vp) = D::preprocess(&mut rng, nova_params, nova.clone()).unwrap(); + let (decider_pp, decider_vp) = + D::preprocess(&mut rng, nova_params.clone(), nova.clone()).unwrap(); // run n steps of the folding iteration for i in 0..5 { diff --git a/examples/noname_full_flow.rs b/examples/noname_full_flow.rs index 996d6227..00dccbfb 100644 --- a/examples/noname_full_flow.rs +++ b/examples/noname_full_flow.rs @@ -89,7 +89,8 @@ fn main() { let mut nova = N::init(&nova_params, f_circuit.clone(), z_0).unwrap(); // prepare the Decider prover & verifier params - let (decider_pp, decider_vp) = D::preprocess(&mut rng, nova_params, nova.clone()).unwrap(); + let (decider_pp, decider_vp) = + D::preprocess(&mut rng, nova_params.clone(), nova.clone()).unwrap(); // run n steps of the folding iteration for (i, external_inputs_at_step) in external_inputs.iter().enumerate() { diff --git a/examples/sha256.rs b/examples/sha256.rs index de555e03..d974d650 100644 --- a/examples/sha256.rs +++ b/examples/sha256.rs @@ -138,10 +138,8 @@ fn main() { println!("Nova::prove_step {}: {:?}", i, start.elapsed()); } - let (running_instance, incoming_instance, cyclefold_instance) = folding_scheme.instances(); - println!("Run the Nova's IVC verifier"); - let ivc_proof = nova.ivc_proof(); + let ivc_proof = folding_scheme.ivc_proof(); N::verify( nova_params.1, // Nova's verifier params ivc_proof, diff --git a/folding-schemes/ivc_proof-hypernova.serialized b/folding-schemes/ivc_proof-hypernova.serialized deleted file mode 100644 index 4e1156fb..00000000 Binary files a/folding-schemes/ivc_proof-hypernova.serialized and /dev/null differ diff --git a/folding-schemes/ivc_proof-nova.serialized b/folding-schemes/ivc_proof-nova.serialized deleted file mode 100644 index 6271ea06..00000000 Binary files a/folding-schemes/ivc_proof-nova.serialized and /dev/null differ diff --git a/folding-schemes/ivc_proof-protogalaxy.serialized b/folding-schemes/ivc_proof-protogalaxy.serialized deleted file mode 100644 index 540f279f..00000000 Binary files a/folding-schemes/ivc_proof-protogalaxy.serialized and /dev/null differ diff --git a/folding-schemes/src/folding/hypernova/mod.rs b/folding-schemes/src/folding/hypernova/mod.rs index 76698a85..239f8691 100644 --- a/folding-schemes/src/folding/hypernova/mod.rs +++ b/folding-schemes/src/folding/hypernova/mod.rs @@ -991,20 +991,6 @@ where self.z_i.clone() } - fn instances( - &self, - ) -> ( - Self::RunningInstance, - Self::IncomingInstance, - Self::CFInstance, - ) { - ( - (self.U_i.clone(), self.W_i.clone()), - (self.u_i.clone(), self.w_i.clone()), - (self.cf_U_i.clone(), self.cf_W_i.clone()), - ) - } - fn ivc_proof(&self) -> Self::IVCProof { Self::IVCProof { i: self.i, @@ -1168,18 +1154,6 @@ mod tests { >( poseidon_config: PoseidonConfig, F_circuit: CubicFCircuit, - ) -> ( - HyperNova, CS1, CS2, 2, 3, H>, - ( - ProverParams, - VerifierParams, - ), - (LCCCS, Witness), - (CCCS, Witness), - ( - CycleFoldCommittedInstance, - CycleFoldWitness, - ), ) { let mut rng = ark_std::test_rng(); @@ -1239,14 +1213,5 @@ mod tests { ivc_proof, ) .unwrap(); - - let (running_instance, incoming_instance, cyclefold_instance) = hypernova.instances(); - ( - hypernova, - hypernova_params, - running_instance, - incoming_instance, - cyclefold_instance, - ) } } diff --git a/folding-schemes/src/folding/mod.rs b/folding-schemes/src/folding/mod.rs index e66a3994..369de725 100644 --- a/folding-schemes/src/folding/mod.rs +++ b/folding-schemes/src/folding/mod.rs @@ -25,8 +25,10 @@ pub mod tests { use crate::Error; use crate::FoldingScheme; + /// tests the IVC proofs and its serializers for the 3 implemented IVCs: Nova, HyperNova and + /// ProtoGalaxy. #[test] - fn test_serialize_ivc() { + fn test_serialize_ivc_nova_hypernova_protogalaxy() { let poseidon_config = poseidon_canonical_config::(); type FC = CubicFCircuit; let f_circuit = FC::new(()).unwrap(); diff --git a/folding-schemes/src/folding/nova/mod.rs b/folding-schemes/src/folding/nova/mod.rs index d1500c2c..9c99d1da 100644 --- a/folding-schemes/src/folding/nova/mod.rs +++ b/folding-schemes/src/folding/nova/mod.rs @@ -344,15 +344,6 @@ where CS2: CommitmentScheme, { fn check(&self) -> Result<(), ark_serialize::SerializationError> { - self.poseidon_config.full_rounds.check()?; - self.poseidon_config.partial_rounds.check()?; - self.poseidon_config.alpha.check()?; - self.poseidon_config.ark.check()?; - self.poseidon_config.mds.check()?; - self.poseidon_config.rate.check()?; - self.poseidon_config.capacity.check()?; - self.r1cs.check()?; - self.cf_r1cs.check()?; self.cs_vp.check()?; self.cf_cs_vp.check()?; Ok(()) @@ -370,7 +361,6 @@ where mut writer: W, compress: ark_serialize::Compress, ) -> Result<(), ark_serialize::SerializationError> { - self.cs_vp.serialize_with_mode(&mut writer, compress)?; self.cs_vp.serialize_with_mode(&mut writer, compress)?; self.cf_cs_vp.serialize_with_mode(&mut writer, compress) } @@ -411,13 +401,13 @@ where // to serialize them, saving significant space in the VerifierParams serialized size. // main circuit R1CS: - let f_circuit = FC::new(fcircuit_params).or(Err(SerializationError::InvalidData))?; + let f_circuit = FC::new(fcircuit_params).map_err(|_| SerializationError::InvalidData)?; let cs = ConstraintSystem::::new_ref(); let augmented_F_circuit = AugmentedFCircuit::::empty(&poseidon_config, f_circuit.clone()); augmented_F_circuit .generate_constraints(cs.clone()) - .or(Err(SerializationError::InvalidData))?; + .map_err(|_| SerializationError::InvalidData)?; cs.finalize(); let cs = cs.into_inner().ok_or(SerializationError::InvalidData)?; let r1cs = extract_r1cs::(&cs); @@ -427,7 +417,7 @@ where let cf_circuit = NovaCycleFoldCircuit::::empty(); cf_circuit .generate_constraints(cs2.clone()) - .or(Err(SerializationError::InvalidData))?; + .map_err(|_| SerializationError::InvalidData)?; cs2.finalize(); let cs2 = cs2.into_inner().ok_or(SerializationError::InvalidData)?; let cf_r1cs = extract_r1cs::(&cs2); @@ -933,20 +923,6 @@ where self.z_i.clone() } - fn instances( - &self, - ) -> ( - Self::RunningInstance, - Self::IncomingInstance, - Self::CFInstance, - ) { - ( - (self.U_i.clone(), self.W_i.clone()), - (self.u_i.clone(), self.w_i.clone()), - (self.cf_U_i.clone(), self.cf_W_i.clone()), - ) - } - fn ivc_proof(&self) -> Self::IVCProof { Self::IVCProof { i: self.i, diff --git a/folding-schemes/src/folding/protogalaxy/mod.rs b/folding-schemes/src/folding/protogalaxy/mod.rs index d12c9041..08a9969c 100644 --- a/folding-schemes/src/folding/protogalaxy/mod.rs +++ b/folding-schemes/src/folding/protogalaxy/mod.rs @@ -917,19 +917,6 @@ where fn state(&self) -> Vec { self.z_i.clone() } - fn instances( - &self, - ) -> ( - Self::RunningInstance, - Self::IncomingInstance, - Self::CFInstance, - ) { - ( - (self.U_i.clone(), self.W_i.clone()), - (self.u_i.clone(), self.w_i.clone()), - (self.cf_U_i.clone(), self.cf_W_i.clone()), - ) - } fn ivc_proof(&self) -> Self::IVCProof { Self::IVCProof { @@ -988,7 +975,7 @@ where }) } - /// Implements IVC.V of Pro.clone()toGalaxy+CycleFold + /// Implements IVC.V of ProtoGalaxy+CycleFold fn verify(vp: Self::VerifierParam, ivc_proof: Self::IVCProof) -> Result<(), Error> { let Self::IVCProof { i: num_steps, diff --git a/folding-schemes/src/lib.rs b/folding-schemes/src/lib.rs index 6909cd8b..e959dd2e 100644 --- a/folding-schemes/src/lib.rs +++ b/folding-schemes/src/lib.rs @@ -154,16 +154,6 @@ where /// returns the state at the current step fn state(&self) -> Vec; - /// returns the instances at the current step, in the following order: - /// (running_instance, incoming_instance, cyclefold_instance) - fn instances( - &self, - ) -> ( - Self::RunningInstance, - Self::IncomingInstance, - Self::CFInstance, - ); - /// returns the last IVC state proof, which can be verified in the `verify` method fn ivc_proof(&self) -> Self::IVCProof;