From b4d82ff5d0e318d3846a607fc5b9e8ee91e336b7 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:15:00 +0000 Subject: [PATCH 01/19] add comment about `add_recursive_proof` being suspicious --- .../proof_system/circuit_builder/circuit_builder_base.hpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/barretenberg/cpp/src/barretenberg/proof_system/circuit_builder/circuit_builder_base.hpp b/barretenberg/cpp/src/barretenberg/proof_system/circuit_builder/circuit_builder_base.hpp index 140d98b234f..12bbc8be31a 100644 --- a/barretenberg/cpp/src/barretenberg/proof_system/circuit_builder/circuit_builder_base.hpp +++ b/barretenberg/cpp/src/barretenberg/proof_system/circuit_builder/circuit_builder_base.hpp @@ -347,11 +347,15 @@ template class CircuitBuilderBase { for (const auto& idx : proof_output_witness_indices) { set_public_input(idx); + // Why is it adding the size of the public input instead of the idx? recursive_proof_public_input_indices.push_back((uint32_t)(public_inputs.size() - 1)); } } /** + * TODO: We can remove this and use `add_recursive_proof` once my question has been addressed + * TODO: using `add_recursive_proof` also means that we will need to remove the cde which is + * TODO: adding the public_inputs * @brief Update recursive_proof_public_input_indices with existing public inputs that represent a recursive proof * * @param proof_output_witness_indices From ac146a4af6dea25b0b86f0ede1ee1c925b853f84 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:15:39 +0000 Subject: [PATCH 02/19] create and process input_aggregation object and output_aggregation_object while building the circuit --- .../dsl/acir_format/acir_format.cpp | 47 +++++++++++++++---- 1 file changed, 38 insertions(+), 9 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp index 6d94ba7b766..aa97d901267 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp @@ -1,6 +1,7 @@ #include "acir_format.hpp" #include "barretenberg/common/log.hpp" #include "barretenberg/dsl/acir_format/pedersen.hpp" +#include "barretenberg/dsl/acir_format/recursion_constraint.hpp" namespace acir_format { @@ -103,19 +104,47 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b create_block_constraints(builder, constraint, has_valid_witness_assignments); } + // These are set and modified whenever we encounter a recursion opcode + // + // These should not be set by the caller + // TODO: Check if this is always the case. ie I won't receive a proof that will set the first + // TODO input_aggregation_object to be non-zero. + // TODO: if not, we can add input_aggregation_object to the proof too for all recursive proofs + // TODO: This might be the case for proof trees where the proofs are created on different machines + std::array current_input_aggregation_object = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 + }; + std::array current_output_aggregation_object = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 + }; + // Add recursion constraints for (size_t i = 0; i < constraint_system.recursion_constraints.size(); ++i) { auto& constraint = constraint_system.recursion_constraints[i]; - create_recursion_constraints(builder, constraint, has_valid_witness_assignments); - - // make sure the verification key records the public input indices of the final recursion output - // (N.B. up to the ACIR description to make sure that the final output aggregation object wires are public - // inputs!) - if (i == constraint_system.recursion_constraints.size() - 1) { - std::vector proof_output_witness_indices(constraint.output_aggregation_object.begin(), - constraint.output_aggregation_object.end()); - builder.set_recursive_proof(proof_output_witness_indices); + current_output_aggregation_object = create_recursion_constraints(builder, + constraint, + current_input_aggregation_object, + constraint.nested_aggregation_object, + has_valid_witness_assignments); + } + + // Now that the circuit has been completely built, we add the output aggregation as public + // inputs and we ensure that they are first in the public inputs vector, so that we can truncate + // them off of the proof by trimming the first 16 * 32 bytes of the proof. + if (!constraint_system.recursion_constraints.empty()) { + + // First add the output aggregation object as public inputs + // Set the indices as public inputs because they are no longer being + // created in ACIR + for (const auto& idx : current_output_aggregation_object) { + builder.set_public_input(idx); } + + // Make sure the verification key records the public input indices of the + // final recursion output. + std::vector proof_output_witness_indices(current_output_aggregation_object.begin(), + current_output_aggregation_object.end()); + builder.set_recursive_proof(proof_output_witness_indices); } } From 92e247d9986ab1c6575d0724f22b941a7f9b4f7c Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:17:54 +0000 Subject: [PATCH 03/19] `create_recursion_constraints` now takes in the input and nested aggregation object --- .../dsl/acir_format/recursion_constraint.hpp | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp index 38a8fde5435..345b6744cd6 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp @@ -53,16 +53,24 @@ struct RecursionConstraint { std::vector proof; std::vector public_inputs; uint32_t key_hash; + // TODO:This is now unused, but we keep it here for backwards compatibility std::array input_aggregation_object; + // TODO: This is now unused, but we keep it here for backwards compatibility std::array output_aggregation_object; + // TODO: This is currently not being used on the Noir level at all + // TODO: we don't have a way to specify that the proof we are creating contains a + // TODO: aggregation object (ie it is also verifying a proof) std::array nested_aggregation_object; friend bool operator==(RecursionConstraint const& lhs, RecursionConstraint const& rhs) = default; }; -void create_recursion_constraints(Builder& builder, - const RecursionConstraint& input, - bool has_valid_witness_assignments = false); +std::array create_recursion_constraints( + Builder& builder, + const RecursionConstraint& input, + std::array input_aggregation_object, + std::array nested_aggregation_object, + bool has_valid_witness_assignments = false); std::vector export_key_in_recursion_format(std::shared_ptr const& vkey); std::vector export_dummy_key_in_recursion_format(const PolynomialManifest& polynomial_manifest, From f36661d0494a72e8fa073212fbcf1b5cf70adabc Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:18:27 +0000 Subject: [PATCH 04/19] add comment on removing the is_recursive flag --- .../barretenberg/dsl/acir_proofs/acir_composer.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/acir_composer.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/acir_composer.cpp index 0dc4a117735..f0730c28d22 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/acir_composer.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_proofs/acir_composer.cpp @@ -106,6 +106,16 @@ bool AcirComposer::verify_proof(std::vector const& proof, bool is_recur // Hack. Shouldn't need to do this. 2144 is size with no public inputs. builder_.public_inputs.resize((proof.size() - 2144) / 32); + // TODO: We could get rid of this, if we made the Noir program specify whether something should be + // TODO: created with the recursive setting or not. ie: + // + // #[recursive_friendly] + // fn main() {} + // would put in the ACIR that we want this to be recursion friendly with a flag maybe and the backend + // would set the is_recursive flag to be true. + // This would eliminate the need for nargo to have a --recursive flag + // + // End result is that we may just be able to get it off of builder_, like builder_.is_recursive_friendly if (is_recursive) { auto verifier = composer.create_verifier(builder_); return verifier.verify_proof({ proof }); @@ -123,6 +133,8 @@ std::string AcirComposer::get_solidity_verifier() } /** + * TODO: We should change this to return a proof without public inputs, since that is what std::verify_proof + * TODO: takes. * @brief Takes in a proof buffer and converts into a vector of field elements. * The Recursion opcode requires the proof serialized as a vector of witnesses. * Use this method to get the witness values! From 738fb17d8d2d8ff9d95a2eddce8027ad6f4360a7 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:19:15 +0000 Subject: [PATCH 05/19] modify `create_recursion_constraints` to append the public inputs to proof fields --- .../dsl/acir_format/recursion_constraint.cpp | 47 ++++++++++++++----- 1 file changed, 34 insertions(+), 13 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp index 0e69aab847e..f01d4f60f66 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp @@ -3,6 +3,7 @@ #include "barretenberg/plonk/transcript/transcript_wrappers.hpp" #include "barretenberg/stdlib/recursion/aggregation_state/aggregation_state.hpp" #include "barretenberg/stdlib/recursion/verifier/verifier.hpp" +#include namespace acir_format { @@ -28,11 +29,19 @@ void generate_dummy_proof() {} * We would either need a separate ACIR opcode where inner_proof_contains_recursive_proof = true, * or we need non-witness data to be provided as metadata in the ACIR opcode */ -void create_recursion_constraints(Builder& builder, - const RecursionConstraint& input, - bool has_valid_witness_assignments) +std::array create_recursion_constraints( + Builder& builder, + const RecursionConstraint& input, + std::array input_aggregation_object, + // TODO: does this need to be a part of the recursion opcode? + // TODO: or can we figure it out from the vk? + // TODO: either way we could probably have the user explicitly provide it + // TODO: in Noir. + // Note: this is not being used in Noir at the moment + std::array nested_aggregation_object, + bool has_valid_witness_assignments) { - const auto& nested_aggregation_indices = input.nested_aggregation_object; + const auto& nested_aggregation_indices = nested_aggregation_object; bool nested_aggregation_indices_all_zero = true; for (const auto& idx : nested_aggregation_indices) { nested_aggregation_indices_all_zero &= (idx == 0); @@ -46,8 +55,12 @@ void create_recursion_constraints(Builder& builder, const std::vector dummy_key = export_dummy_key_in_recursion_format( PolynomialManifest(Builder::CIRCUIT_TYPE), inner_proof_contains_recursive_proof); const auto manifest = Composer::create_manifest(input.public_inputs.size()); - const std::vector dummy_proof = + std::vector dummy_proof = export_dummy_transcript_in_recursion_format(manifest, inner_proof_contains_recursive_proof); + + // Remove the public inputs from the dummy proof + dummy_proof.erase(dummy_proof.begin(), + dummy_proof.begin() + static_cast(input.public_inputs.size())); for (size_t i = 0; i < input.proof.size(); ++i) { const auto proof_field_idx = input.proof[i]; // if we do NOT have a witness assignment (i.e. are just building the proving/verification keys), @@ -73,7 +86,7 @@ void create_recursion_constraints(Builder& builder, // Construct an in-circuit representation of the verification key. // For now, the v-key is a circuit constant and is fixed for the circuit. // (We may need a separate recursion opcode for this to vary, or add more config witnesses to this opcode) - const auto& aggregation_input = input.input_aggregation_object; + const auto& aggregation_input = input_aggregation_object; aggregation_state_ct previous_aggregation; // If we have previously recursively verified proofs, `is_aggregation_object_nonzero = true` @@ -112,7 +125,13 @@ void create_recursion_constraints(Builder& builder, } std::vector proof_fields; - proof_fields.reserve(input.proof.size()); + // Prepend the public inputs to the proof fields because this is how the + // core barretenberg library processes proofs (with the public inputs first and not separated) + proof_fields.reserve(input.proof.size() + input.public_inputs.size()); + for (const auto& idx : input.public_inputs) { + auto field = field_ct::from_witness_index(&builder, idx); + proof_fields.emplace_back(field); + } for (const auto& idx : input.proof) { auto field = field_ct::from_witness_index(&builder, idx); proof_fields.emplace_back(field); @@ -136,12 +155,14 @@ void create_recursion_constraints(Builder& builder, result.public_inputs[i].assert_equal(field_ct::from_witness_index(&builder, input.public_inputs[i])); } - // Assign the recursive proof outputs to `output_aggregation_object` - for (size_t i = 0; i < result.proof_witness_indices.size(); ++i) { - const auto lhs = field_ct::from_witness_index(&builder, result.proof_witness_indices[i]); - const auto rhs = field_ct::from_witness_index(&builder, input.output_aggregation_object[i]); - lhs.assert_equal(rhs); - } + // We want to return an array, so just copy the vector into the array + ASSERT(result.proof_witness_indices.size() == RecursionConstraint::AGGREGATION_OBJECT_SIZE); + std::array resulting_output_aggregation_object; + std::copy(result.proof_witness_indices.begin(), + result.proof_witness_indices.begin() + RecursionConstraint::AGGREGATION_OBJECT_SIZE, + resulting_output_aggregation_object.begin()); + + return resulting_output_aggregation_object; } /** From cab6ef6870301d15adb86ced20e9b93aba36670b Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:19:48 +0000 Subject: [PATCH 06/19] update double_verify_proof program --- .../double_verify_proof/Prover.toml | 9 +++--- .../double_verify_proof/src/main.nr | 31 ++++++++++--------- 2 files changed, 21 insertions(+), 19 deletions(-) diff --git a/noir/test_programs/execution_success/double_verify_proof/Prover.toml b/noir/test_programs/execution_success/double_verify_proof/Prover.toml index 3e6d996d0e1..162c9a5060c 100644 --- a/noir/test_programs/execution_success/double_verify_proof/Prover.toml +++ b/noir/test_programs/execution_success/double_verify_proof/Prover.toml @@ -1,12 +1,11 @@ -input_aggregation_object = ["0", "0", "0", "0", "0", "0", "0", "0", "0", "0", "0", "0", "0", "0", "0", "0"] # key_hash = "0x17a5d2b205c1bf45b015ba33bc2f0beb7fbb36682f31f953b8d4d093c8644be5" -# proof = ["0x0000000000000000000000000000000000000000000000000000000000000003","0x0000000000000000000000000000008f66908323784e7c5259f4eefab77ca881","0x0000000000000000000000000000000000109cac7b943f9b737d7b023d4f5d8a","0x000000000000000000000000000000e991d3ac0a68a252bd3cd09cd1b43fe1b4","0x000000000000000000000000000000000014213d346a426777351fdabaa0fa26","0x000000000000000000000000000000e4603692a76af630015380b08d0e13c239","0x0000000000000000000000000000000000149e7046461203c1b72392bb93c262","0x000000000000000000000000000000c27ffc719f223ca6ef5476a5b66f03a4a8","0x000000000000000000000000000000000003718c62098243e3c1f38090e61753","0x000000000000000000000000000000749492aa98716ce5bf7c06e5c2a0a8a528","0x000000000000000000000000000000000018e4c7d33848bccdc3eed924bfaa15","0x0000000000000000000000000000004e10a37f41fd7c4fe32982daa498530d62","0x00000000000000000000000000000000001b76c8c59489c63f11280187109dd7","0x0000000000000000000000000000002a6cd84d3b8537a7c3cb0cb9461f02e4bb","0x0000000000000000000000000000000000197e524fd48ca5ccb30d6c5ffe689d","0x0000000000000000000000000000000013bf25498ce1f51078c06dac450c0325","0x000000000000000000000000000000000018d347b88a0c32e32571deb9b40466","0x00000000000000000000000000000060d496191298eb1b1c2ce18f9a4afcfc55","0x000000000000000000000000000000000024e11b8e8fcb45b8628cb9cc565513","0x00000000000000000000000000000004e976f6d12fff6250eea2d21c570d3d6a","0x00000000000000000000000000000000000967dbd89d2c7dc0121ea71ded7203","0x000000000000000000000000000000d96f810588c0daa43e88d765a3f82ea9b7","0x00000000000000000000000000000000001f69d7015fe6694bd1d4d61049dae9","0x000000000000000000000000000000c539910d0f81a890fa3d996a676db39640","0x000000000000000000000000000000000026d8b64020a669e24f740b4eba633a","0x000000000000000000000000000000c53cc90f99c40eb5d449f38180d9e9c8b6","0x00000000000000000000000000000000001071ddf2bacc2367dfb2c5084b7dd1","0x0000000000000000000000000000001b9791181eb174db1a50d903fa9fea9999","0x0000000000000000000000000000000000118c059d41a95311a5c361c6a9a00d","0x0000000000000000000000000000003caf4ad04551a3ffba19cc6a1fff457370","0x00000000000000000000000000000000001dc4d8be804c5289fbf54183f93149","0x00000000000000000000000000000050766764bb82799df5172043c515956263","0x00000000000000000000000000000000000a5849adbac9c33e53571b29aab672","0x0000000000000000000000000000002edb078e589d44ac93e283680b34adf574","0x000000000000000000000000000000000015e9e187c4fb683ca78d52a2a0301b","0x00000000000000000000000000000048ac0f1db3575ed0f84d61ab6cbdd53d9f","0x00000000000000000000000000000000002ddc4243fbc7104347d29a823194ae","0x00000000000000000000000000000070ad92aeea2bdea4277ffdfa3d3ed93443","0x000000000000000000000000000000000003bad3e3aae806c278094cb682a8e0","0x000000000000000000000000000000fb74b99eb44c80d8f7ba83d7e9e2efa5c0","0x00000000000000000000000000000000002819cc14e399c1dadc4f921e2a58fa","0x000000000000000000000000000000e3938bb3e7866c6499ec44fb72549efca0","0x00000000000000000000000000000000002d8264d5cdc2109da12e1864aca147","0x000000000000000000000000000000b12d7828cacbe86350f0b171b0cb0d1cd4","0x0000000000000000000000000000000000244155cecb315326f05641cac9475c","0x070b059f9471e22eed5a9ea08093dba3c59c941634611884c5f0f1a1a6b93e5c","0x118124ada70b46c7d23a6ca8b90d545f30e028b1689fe5c55c86bf55f42e0401","0x25dca6ad78c03ce1f7783cc39a5ea5ef90b318d5edf4f1367d4451c1db3c113e","0x0d9557b4e661b5c53b84fcb41f05d15c0ca112430db16f56d0ab54032fffe734","0x06aedf13a3b182784f4d64162f4706759f95e42fc8dc17d1b8b5f551dafdc007","0x132f97ab5f1f8817689b17e336125c5273d6970a1b3b0901fd26d193a4d2dce4","0x1b0c9980b5b09343e807d82bad307a06d1bfadcd1fa50be666c2907d31ef43e1","0x1ce7000cb24ecc1f2ff9d9507b2290513fed574a84d893811cb54a3c0bc51ccc","0x2e1df58d36444c2dfda98991847422f56ef66f079d26eb7f8110d0d7c46b2c0c","0x166c2f821be7c3e3e4440980e73770840194f14d003778b7fbcdd2690776255c","0x1ae8390287e2eb117851a5011575ba3801e5ee5c66a8f7432e2a2fb13c276008","0x047c09806bfb272d940d9b802e3e49b40050fd0f66717e8b325c5d4834b13aac","0x08f81300d7f64e5b281b37005c7c936800a1fa1ecce2fd1664b8ba9069627558","0x2ed7260e623b68d580304751341bb72141314b881e9e8dade626bf5cde8a077c","0x23e04c035fd9396ca06cdc0171f24da00287e87b338bf45992e2ea41a589d560","0x285c5583cbd4609a347a7781a030975402d8e58a99fd72e4c53f4789da3b100c","0x2cd85f0437cf87c7c8881301ce6ee1080329e29a006ef16ff79ba4d20eec4ab8","0x12eb74da267caf98c494db16c87f90f510fdca1f8095b40156a6f0bb066e3400","0x2267004535c434df4cbee1a356e48b1f317cb849ac69c3eb94e377d2274f1e08","0x2c9d4ce9d1d8b8cf1cb90cbc3e121f570c8260c53b48ed2070d474d5a6f12c4e","0x2c6c83ffaad6f30da5aa696973ccfbd0337cb7a5e5f9e5fc8e826dce21e8f51c","0x056c23922e9435f93853044ba96a1c12db97f47053987df5187269ce884ec00f","0x09e82d129a8f5d26cc609fcbd7a865c6dbe8f17fba09fc804acec716bcfffabb","0x0e643693068a8454606e3b4c05e6af7adc39ee8f207b7b0b7d2b245ef1b13567","0x12e040137285ab81f47bd6cc3424f92edc8aeb9e86ecf996af8781a726627013","0x00f01a11c2990ecba44568cb7b2bd25edb46f760ed26ff69e6160c86539d8563","0x28a91699dfa4e85e18e8621d39a147a40930701d2d88546e01adb71a1f8e407f","0x000000000000000000000000000000009d7cc0b2d2bdef816f4fb17e7a6f6c08","0x00000000000000000000000000000000bcfc1a7030171f681f2c6e97c61f4e70","0x00000000000000000000000000000000dc7b742d8d704f4ecf092bb111cf30d8","0x13b099dc4869006fde9df04bf36f4c8f08d4491cc6229ac36a98f93214c79b6a","0x008fa95e0d431d617d8d3288fde7f8bbe36492019943e2018564633528575892","0x0fc66c06bdff20dba4dc491d5cd13cc209c4d2d9e29802db665bb397c2a4e754","0x0fe48ae6623efbaadce6d6b75b87be6caa19c2fd4d94a74149ceb6bcb88251e1","0x1bb41738028855cb5e0085edcd62cff208121427ea19a57425a0cf6bb68deb93","0x0fbc646333ddc21ab1a77b01a35973a56d5a617c482a21a231497fd3cc9b74c1","0x19ab9eaa1a902faff2dd9baa19ff00cea9086baa8c28bcdb95f7a3549eaf09b4","0x25e2b7a7643df4d964cd787b593888b00abfe3ce79e8deaa6d68fd1686b84bcb","0x2d134d7eea07414451e54854d61d5b71245434d0638bba9a1184914f65f2521c","0x03df94e38e9eed8586acd277d180d5d515b49d89d37525f871be2ff4552c586c","0x0b102abb146839f073c4a2514e65a8962f48ee8bbd1801e815d9c42d34665ebd","0x000000000000000000000000000000b7a4109cb92b514401fb63667454a9c892","0x0000000000000000000000000000000000016fce7f8ef56fef466636f3fbc3de","0x00000000000000000000000000000005f2d1c401a7aa14ac7e9fce7c21ec2e1a","0x00000000000000000000000000000000000621322c74c5d0da5eb71a4f2b046f","0x00000000000000000000000000000073d774ad7f61b1c1b93800f7838cca6bde","0x00000000000000000000000000000000002d603cc025e6af192394df113d4677","0x00000000000000000000000000000066a2a702b4d4b1a24af9c56cacb18ae4b8","0x00000000000000000000000000000000000124a3c25b427cfb6fca07525c5b8d"] +# proof = ["0x0000000000000000000000000000008f66908323784e7c5259f4eefab77ca881","0x0000000000000000000000000000000000109cac7b943f9b737d7b023d4f5d8a","0x000000000000000000000000000000e991d3ac0a68a252bd3cd09cd1b43fe1b4","0x000000000000000000000000000000000014213d346a426777351fdabaa0fa26","0x000000000000000000000000000000e4603692a76af630015380b08d0e13c239","0x0000000000000000000000000000000000149e7046461203c1b72392bb93c262","0x000000000000000000000000000000c27ffc719f223ca6ef5476a5b66f03a4a8","0x000000000000000000000000000000000003718c62098243e3c1f38090e61753","0x000000000000000000000000000000749492aa98716ce5bf7c06e5c2a0a8a528","0x000000000000000000000000000000000018e4c7d33848bccdc3eed924bfaa15","0x0000000000000000000000000000004e10a37f41fd7c4fe32982daa498530d62","0x00000000000000000000000000000000001b76c8c59489c63f11280187109dd7","0x0000000000000000000000000000002a6cd84d3b8537a7c3cb0cb9461f02e4bb","0x0000000000000000000000000000000000197e524fd48ca5ccb30d6c5ffe689d","0x0000000000000000000000000000000013bf25498ce1f51078c06dac450c0325","0x000000000000000000000000000000000018d347b88a0c32e32571deb9b40466","0x00000000000000000000000000000060d496191298eb1b1c2ce18f9a4afcfc55","0x000000000000000000000000000000000024e11b8e8fcb45b8628cb9cc565513","0x00000000000000000000000000000004e976f6d12fff6250eea2d21c570d3d6a","0x00000000000000000000000000000000000967dbd89d2c7dc0121ea71ded7203","0x000000000000000000000000000000d96f810588c0daa43e88d765a3f82ea9b7","0x00000000000000000000000000000000001f69d7015fe6694bd1d4d61049dae9","0x000000000000000000000000000000c539910d0f81a890fa3d996a676db39640","0x000000000000000000000000000000000026d8b64020a669e24f740b4eba633a","0x000000000000000000000000000000c53cc90f99c40eb5d449f38180d9e9c8b6","0x00000000000000000000000000000000001071ddf2bacc2367dfb2c5084b7dd1","0x0000000000000000000000000000001b9791181eb174db1a50d903fa9fea9999","0x0000000000000000000000000000000000118c059d41a95311a5c361c6a9a00d","0x0000000000000000000000000000003caf4ad04551a3ffba19cc6a1fff457370","0x00000000000000000000000000000000001dc4d8be804c5289fbf54183f93149","0x00000000000000000000000000000050766764bb82799df5172043c515956263","0x00000000000000000000000000000000000a5849adbac9c33e53571b29aab672","0x0000000000000000000000000000002edb078e589d44ac93e283680b34adf574","0x000000000000000000000000000000000015e9e187c4fb683ca78d52a2a0301b","0x00000000000000000000000000000048ac0f1db3575ed0f84d61ab6cbdd53d9f","0x00000000000000000000000000000000002ddc4243fbc7104347d29a823194ae","0x00000000000000000000000000000070ad92aeea2bdea4277ffdfa3d3ed93443","0x000000000000000000000000000000000003bad3e3aae806c278094cb682a8e0","0x000000000000000000000000000000fb74b99eb44c80d8f7ba83d7e9e2efa5c0","0x00000000000000000000000000000000002819cc14e399c1dadc4f921e2a58fa","0x000000000000000000000000000000e3938bb3e7866c6499ec44fb72549efca0","0x00000000000000000000000000000000002d8264d5cdc2109da12e1864aca147","0x000000000000000000000000000000b12d7828cacbe86350f0b171b0cb0d1cd4","0x0000000000000000000000000000000000244155cecb315326f05641cac9475c","0x070b059f9471e22eed5a9ea08093dba3c59c941634611884c5f0f1a1a6b93e5c","0x118124ada70b46c7d23a6ca8b90d545f30e028b1689fe5c55c86bf55f42e0401","0x25dca6ad78c03ce1f7783cc39a5ea5ef90b318d5edf4f1367d4451c1db3c113e","0x0d9557b4e661b5c53b84fcb41f05d15c0ca112430db16f56d0ab54032fffe734","0x06aedf13a3b182784f4d64162f4706759f95e42fc8dc17d1b8b5f551dafdc007","0x132f97ab5f1f8817689b17e336125c5273d6970a1b3b0901fd26d193a4d2dce4","0x1b0c9980b5b09343e807d82bad307a06d1bfadcd1fa50be666c2907d31ef43e1","0x1ce7000cb24ecc1f2ff9d9507b2290513fed574a84d893811cb54a3c0bc51ccc","0x2e1df58d36444c2dfda98991847422f56ef66f079d26eb7f8110d0d7c46b2c0c","0x166c2f821be7c3e3e4440980e73770840194f14d003778b7fbcdd2690776255c","0x1ae8390287e2eb117851a5011575ba3801e5ee5c66a8f7432e2a2fb13c276008","0x047c09806bfb272d940d9b802e3e49b40050fd0f66717e8b325c5d4834b13aac","0x08f81300d7f64e5b281b37005c7c936800a1fa1ecce2fd1664b8ba9069627558","0x2ed7260e623b68d580304751341bb72141314b881e9e8dade626bf5cde8a077c","0x23e04c035fd9396ca06cdc0171f24da00287e87b338bf45992e2ea41a589d560","0x285c5583cbd4609a347a7781a030975402d8e58a99fd72e4c53f4789da3b100c","0x2cd85f0437cf87c7c8881301ce6ee1080329e29a006ef16ff79ba4d20eec4ab8","0x12eb74da267caf98c494db16c87f90f510fdca1f8095b40156a6f0bb066e3400","0x2267004535c434df4cbee1a356e48b1f317cb849ac69c3eb94e377d2274f1e08","0x2c9d4ce9d1d8b8cf1cb90cbc3e121f570c8260c53b48ed2070d474d5a6f12c4e","0x2c6c83ffaad6f30da5aa696973ccfbd0337cb7a5e5f9e5fc8e826dce21e8f51c","0x056c23922e9435f93853044ba96a1c12db97f47053987df5187269ce884ec00f","0x09e82d129a8f5d26cc609fcbd7a865c6dbe8f17fba09fc804acec716bcfffabb","0x0e643693068a8454606e3b4c05e6af7adc39ee8f207b7b0b7d2b245ef1b13567","0x12e040137285ab81f47bd6cc3424f92edc8aeb9e86ecf996af8781a726627013","0x00f01a11c2990ecba44568cb7b2bd25edb46f760ed26ff69e6160c86539d8563","0x28a91699dfa4e85e18e8621d39a147a40930701d2d88546e01adb71a1f8e407f","0x000000000000000000000000000000009d7cc0b2d2bdef816f4fb17e7a6f6c08","0x00000000000000000000000000000000bcfc1a7030171f681f2c6e97c61f4e70","0x00000000000000000000000000000000dc7b742d8d704f4ecf092bb111cf30d8","0x13b099dc4869006fde9df04bf36f4c8f08d4491cc6229ac36a98f93214c79b6a","0x008fa95e0d431d617d8d3288fde7f8bbe36492019943e2018564633528575892","0x0fc66c06bdff20dba4dc491d5cd13cc209c4d2d9e29802db665bb397c2a4e754","0x0fe48ae6623efbaadce6d6b75b87be6caa19c2fd4d94a74149ceb6bcb88251e1","0x1bb41738028855cb5e0085edcd62cff208121427ea19a57425a0cf6bb68deb93","0x0fbc646333ddc21ab1a77b01a35973a56d5a617c482a21a231497fd3cc9b74c1","0x19ab9eaa1a902faff2dd9baa19ff00cea9086baa8c28bcdb95f7a3549eaf09b4","0x25e2b7a7643df4d964cd787b593888b00abfe3ce79e8deaa6d68fd1686b84bcb","0x2d134d7eea07414451e54854d61d5b71245434d0638bba9a1184914f65f2521c","0x03df94e38e9eed8586acd277d180d5d515b49d89d37525f871be2ff4552c586c","0x0b102abb146839f073c4a2514e65a8962f48ee8bbd1801e815d9c42d34665ebd","0x000000000000000000000000000000b7a4109cb92b514401fb63667454a9c892","0x0000000000000000000000000000000000016fce7f8ef56fef466636f3fbc3de","0x00000000000000000000000000000005f2d1c401a7aa14ac7e9fce7c21ec2e1a","0x00000000000000000000000000000000000621322c74c5d0da5eb71a4f2b046f","0x00000000000000000000000000000073d774ad7f61b1c1b93800f7838cca6bde","0x00000000000000000000000000000000002d603cc025e6af192394df113d4677","0x00000000000000000000000000000066a2a702b4d4b1a24af9c56cacb18ae4b8","0x00000000000000000000000000000000000124a3c25b427cfb6fca07525c5b8d"] # public_inputs = ["0x0000000000000000000000000000000000000000000000000000000000000003"] # verification_key = ["0x2b337de1c8c14f22ec9b9e2f96afef3652627366f8170a0a948dad4ac1bd5e80","0x0000000000000000000000000000000000000000000000000000000000000008","0x0000000000000000000000000000000000000000000000000000000000000005","0x0000000000000000000000000000000000000000000000000000000000000008","0x0000000000000000000000000000000000000000000000000000000000000001","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x00000000000000000000000000000092139c61bae1a44f0fc7689507414be688","0x00000000000000000000000000000000000160ce4e279582f91bde4f03f5e9a2","0x0000000000000000000000000000005dc2d37f658c3b2d60f24740eb13b65d79","0x000000000000000000000000000000000007e3e8a5d98a1177ec85bf88f163a5","0x000000000000000000000000000000dc3035fbd7ff16412a8fd7da587a935298","0x000000000000000000000000000000000023d08e2817ac16990004ed11d8fc66","0x000000000000000000000000000000356a5ad59c646c746a8d09f5d154e47c4f","0x00000000000000000000000000000000000708529196af3c8e16ffa580c26182","0x0000000000000000000000000000002ddfe70eb7a1280596e8e4a804f118a6dd","0x000000000000000000000000000000000013757e15a0905f298303784a161b21","0x000000000000000000000000000000a23a729df796935c7824e3a26be794829b","0x000000000000000000000000000000000005775b6c146c4a59856e869fe5a70e","0x000000000000000000000000000000eef0c9e088fd2d45aa40311082d1f2809b","0x00000000000000000000000000000000001d539ccbfc556d0ad59307a218de65","0x000000000000000000000000000000a2c848beceb6ab7806fd3b88037b8410fc","0x0000000000000000000000000000000000177004deeb1f9d401fd7b1af1a5ac8","0x0000000000000000000000000000002508eb63672a733f20de1a97644be4f540","0x00000000000000000000000000000000000d82d51f2f75d806285fd248c819b8","0x000000000000000000000000000000d002f9100cbba8a29f13b11513c53c59d0","0x000000000000000000000000000000000006cd3b0e3460533b9e5ea2cdc0fcbb","0x000000000000000000000000000000f45ea38a93b2f810c5633ddb54927c1c96","0x000000000000000000000000000000000021791de65f9a28ec7024b1a87ab4f3","0x000000000000000000000000000000926511a0439502c86885a8c6f0327aa7ad","0x000000000000000000000000000000000029fa14a969c5d81ed3abbbfb11220a","0x000000000000000000000000000000b84c3258e8206f560e5b5b18cbeafef87e","0x00000000000000000000000000000000002a910445cd8fc895e5d235cd8ea185","0x000000000000000000000000000000887e67f15e84bcb8507a5064a363f6043b","0x000000000000000000000000000000000014dc6643d801c3ef27c2066b6e2bb4","0x000000000000000000000000000000e38e900b42c314ba803088e8fbf125203f","0x000000000000000000000000000000000020690fd4869db418306046b38161dc","0x0000000000000000000000000000001e2fa856bf7951b8292b1e88185993629c","0x0000000000000000000000000000000000048a85e0bbac7c60ad3d78f601f63c","0x0000000000000000000000000000006f457719495073d3666d77a625aeab0c51","0x00000000000000000000000000000000002623ad892dc62b1fa7d0a650f0d470","0x000000000000000000000000000000dbfcc8a467e021c03b13f74a9f79c3a10c","0x0000000000000000000000000000000000295f6f10976c37bd9c6f96bb7187d5","0x000000000000000000000000000000c13ef9a937cc12420fb38d9ab8e848e85e","0x000000000000000000000000000000000003560a3b334e887532f605c9cb7628","0x0000000000000000000000000000009bcebf08a4599cdda0fb96312d4dc0c7a9","0x000000000000000000000000000000000015adc8bb1e01c835f48959d1237bd6","0x00000000000000000000000000000047762ab839e4ff63c77605a9f383da37c2","0x000000000000000000000000000000000016a8c3c53d89660cf271522cd301fb","0x000000000000000000000000000000f0c8539a0b5f94420a513f9c305b932bfe","0x00000000000000000000000000000000002957ba01d9de5638f808f88a692533","0x000000000000000000000000000000ab17c6189d67d3bf5dd2f3885de0151b6f","0x0000000000000000000000000000000000060d8aa43fdc434d1942263f364d95","0x0000000000000000000000000000005d292333b3adb497f00b4bc32d45229060","0x00000000000000000000000000000000001a1018a66221883639f2898a66f345","0x00000000000000000000000000000006555a806b1993291deba0dc44e2abf431","0x00000000000000000000000000000000000cacff7099a9d5e35a21f4a00b2dc3","0x000000000000000000000000000000f50c11ba95d349c36d143eefd12e494950","0x00000000000000000000000000000000001022e8c5f02d639bc9dd8bc4407f99","0x000000000000000000000000000000c76828795098eda73d50b4b585c60afc60","0x00000000000000000000000000000000002bf09c0ec7011e93888962f2406630","0x00000000000000000000000000000049e5c83a8978d832fb8e144548e3ca1adb","0x00000000000000000000000000000000000e0ec242c2e160a984f61ca5adf5f5","0x0000000000000000000000000000009c5d6e08a6605ab4513748ac0fa017dd1c","0x00000000000000000000000000000000001f54baa07558e5fb055bd9ba49c067","0x0000000000000000000000000000001e1ee7ee29bbb5e4b080c6091c1433ce62","0x000000000000000000000000000000000024aec62a9d9763499267dc98c33428","0x0000000000000000000000000000001a96755946ff16f0d6632365f0eb0ab4d4","0x000000000000000000000000000000000028cf3e22bcd53782ebc3e0490e27e5","0x00000000000000000000000000000043148d7d8c9ba43f2133fab4201435a364","0x0000000000000000000000000000000000234ce541f1f5117dd404cfaf01a229","0x000000000000000000000000000000a7fb95ffb461d9514a1070e2d2403982ef","0x00000000000000000000000000000000003016955028b6390f446c3fd0c5b424","0x00000000000000000000000000000008863c3b7cd7cddc20ba79ce915051c56e","0x000000000000000000000000000000000013ef666111b0be56a235983d397d2a","0x000000000000000000000000000000e3993f465fc9f56e93ac769e597b752c1c","0x0000000000000000000000000000000000217f7c4235161e9a3c16c45b6ca499","0x0000000000000000000000000000008ffa4cd96bc67b0b7df5678271e1114075","0x0000000000000000000000000000000000256467bfcb63d9fdcb5dde397757ad","0x00000000000000000000000000000054e5eb270bb64bde6e6ececadfd8c3236c","0x00000000000000000000000000000000000e52d1bd75812c33c6f3d79ee4b94c","0x000000000000000000000000000000484a2c641dce55bc2dd64ef0cd790a7fea","0x00000000000000000000000000000000000ff417d256be43e73c8b1aa85bdda3","0x0000000000000000000000000000000b72e7b7713ab5da44e0f864182e748a23","0x00000000000000000000000000000000001a221055f1625ad833a44705f5f74e","0x00000000000000000000000000000067a99a34e9b81a17ad001db02e29bcb82a","0x000000000000000000000000000000000018a6c02e398389827568fa960e86e2","0x000000000000000000000000000000bb29f26f9890d6cc6401f4921d5884edca","0x00000000000000000000000000000000000868357b28039385c5a5058b6d358e","0x00000000000000000000000000000036fb6e229dde8edf7ec858b12d7e8be485","0x00000000000000000000000000000000001060afe929554ca473103f5e68193c","0x00000000000000000000000000000015226e07e207744c0857074dcab883af4a","0x00000000000000000000000000000000000b1c02619282755533457230b19b4a","0x0000000000000000000000000000001f2a0277e4807e6e1cbabca21dde5eb5e1","0x00000000000000000000000000000000000d928deafed363659688ed4ccdef52","0x000000000000000000000000000000363f0c994e91cecad25835338edee2294f","0x00000000000000000000000000000000002eea648c8732596b1314fe2a4d2f05","0x000000000000000000000000000000b2671d2ae51d31c1210433c3972bb64578","0x00000000000000000000000000000000000ab49886c2b94bd0bd3f6ed1dbbe2c"] -# proof_b = ["0x0000000000000000000000000000000000000000000000000000000000000003","0x0000000000000000000000000000002ab91b132e624f2a408aa8c9bf31cca8d7","0x000000000000000000000000000000000015ad57528e0f065c820cc5ad4eab81","0x0000000000000000000000000000001acb78b1b6a5c9a6ec8bf2272b463014da","0x0000000000000000000000000000000000117fd65346e04bf3666d2ab3f24c90","0x000000000000000000000000000000aad0adaf9a768ba6a178f804edac5c8943","0x000000000000000000000000000000000004a11c7d31f25c20e3af16f9b01f71","0x0000000000000000000000000000001f0ae9bb921893ce2710148eb1fcd99e39","0x0000000000000000000000000000000000123fda5008d3709f5afeda01de1930","0x000000000000000000000000000000971c2a8d0119097fd82b7a8074a14853f8","0x000000000000000000000000000000000009965b998750710678da7891d8aba6","0x0000000000000000000000000000002d6ef3813ba14a5f5202afed6b1c41de1c","0x000000000000000000000000000000000020366bfdb2f9279c43d66f90dfdf4d","0x00000000000000000000000000000041389f221eadec33e1b87518668c3bc92e","0x00000000000000000000000000000000000d3858169bb0432ab761d4be8ef03e","0x000000000000000000000000000000c1dbfe670dc912cb0fa1a0f633f81a4cef","0x00000000000000000000000000000000000fc0c403e668b0f51e07089082c32f","0x0000000000000000000000000000009a4fba9bf1369f637fd295c8bf795c9d02","0x00000000000000000000000000000000001d6d1e7286ce52401e6ea79d2cfa3d","0x0000000000000000000000000000004762bf7702ffe7a2c147e704280cd50bba","0x0000000000000000000000000000000000205797cdeaeff9a8d5ea4b95d41b1a","0x000000000000000000000000000000b3d43cc863ba8d98f51118c0db70761079","0x00000000000000000000000000000000002d2a3d10381bc6b47a693c1692b1b6","0x000000000000000000000000000000d35a69fb0e68729f71e651799c0d19e9eb","0x00000000000000000000000000000000002ade1dc7741b7f397271c10e596557","0x0000000000000000000000000000001a67b44714687085004e4142f700043298","0x00000000000000000000000000000000001bb7bbb7f45876b1d72e5d20cee106","0x00000000000000000000000000000025f1f1cbf43fad70cba255b37a19e88b0c","0x00000000000000000000000000000000000cc46b215fbd8e4b233cc74aab250b","0x0000000000000000000000000000008168026f51135fc1670664bc50e629917f","0x000000000000000000000000000000000004d822d80ba0c1bcbd4b000573c6f9","0x000000000000000000000000000000d85756249b937277eba3f5dcb89c56e7bb","0x000000000000000000000000000000000019a3a7a5b20dac138d7ddb1d499134","0x0000000000000000000000000000007621614c7ebc31a2177011f9da01668eb3","0x000000000000000000000000000000000024e9beb5d616ab120073170fc431e8","0x00000000000000000000000000000031fbf901896e958fbbed3e5c57aebbdd04","0x0000000000000000000000000000000000005ac0f10fcc255e179a40518875d4","0x0000000000000000000000000000002dab820c019bcca563b7dbdd26974653e9","0x00000000000000000000000000000000001a5655ec1a67f722b14c65d5c2197f","0x0000000000000000000000000000008e277e490196db5c19d09a9034e10c6432","0x000000000000000000000000000000000003f13b1af07db07eec88698d0aaf2a","0x0000000000000000000000000000002d618452e2b4c790d0551ea5863ed62e76","0x00000000000000000000000000000000001a7171e790a433a972d80218fb482d","0x0000000000000000000000000000005669975cd5bf65a739c0a35a8ab9b7963b","0x00000000000000000000000000000000000d27ffb6f00c86a0ce76a8067d1bce","0x03a0054fe9f93ab96e7c7ed6ec1ac641dffd99a1c804ee5db52cf1efa1a12c15","0x059324381c89c12c87d0f6c27963c31647721fdb02c125961da1a21cbfb3ed1c","0x04a5ead891b7c3f30329e6abcf2ac6903c3c1d8e68874f6baf3a6fc00e84533a","0x03c02f6b862734acf9d0c5133f8141b3a008c5499336a588b376a5dd86d9c837","0x1dd26b35c21c584c410df89d1fd549e7f5da9bb4fd290b7c528d92fbd652f5ad","0x2c8e7ef6f7a130769ae74d0f47aeab5c443492ef4b1ed0b3a9d61dfca80cbdda","0x2b074486c21c62e6eccf3191b3ab3c8df0fb98f0c44b9f0e9e2c281b908b83a6","0x149a6d620be135bba6bbfe8ac826df37567c8be78007e47cdcf5d6e4683d339e","0x119fdfd330036bde31af71e43bd5e191460605e4760d08a6e0ebddbdb5abfeeb","0x1713efc63c00b2de4f68e696d9d30c5603963484f4829e716de2796640864b09","0x1bb1862114cda3712c177b1b6bca0ecd9de7723925698aee83dc91ade7078d3e","0x049d965ad8ccf092dcae948491f702779a513db430e6ec7d15fa1847a6814235","0x093b2cb5b199e125b95d290923ee04ef34a27b6861cdd8fa2bf4308f4d02846a","0x2710c6cd6f14f8071976509d1002e915bfc182b843a3967134de380302423c72","0x24ecb2d6c6678496e574a4248fb813bcd289eda1873763e8afd0c23d340a11a8","0x298a49319f347529c22338a921af16346cdb2b55b81e5065c5cada84da8b53dd","0x2e27df8c780165bc9ed1cd2db3a618ac072c6909e9053ce2dbc4f2cc810c9612","0x07350f3a2e23c1ccbde0d39370159060de5b8df40ae7c58d3f9852b371f1adac","0x2fdf8bf8e2fa2acad0f6d6a3f73e7dc516e8e2d167128bf3a560972339122835","0x0d3ec457703c228d4b6cd1635df9d9bde51997d0228edef64d667cbd16f3cb70","0x148320b9ceab1f3be840dc38b0344e7db0755283d1eacf2dd472e99ee0fb473f","0x06febdcf4869a6b89fdeb0805612c53e139afc29d119a54bc3d72dc7de0f1a7b","0x0b9c542a2136974b7c8d4504e809c7b5adec39de020091c8d9d1460f84905cb0","0x1039ea84fa0387de593bd9897a00ca2d483d779232e77e45efcb5e572b119ee5","0x14d780dfd2d0787135ea6e0e0bf7cca4e28eb54663ce6ac305c5769ed192e11a","0x026127746f9cb625c3301bfbc41bc2c67949be75a032b8ceaddd1580378dd846","0x123cf1180af5fdf09444de423947c9a71790f2c85468b51ecc25fb7bf075a0d5","0x000000000000000000000000000000008419a4f769ceb72c3ac28f559331a5df","0x000000000000000000000000000000009e852c5c1891a89b79b64599e3d52d72","0x00000000000000000000000000000000b8f0b3c0c7549a0ab8a9fbde3478b505","0x056af493dda97ae84cdbbf9ce379e35bdd66e1223eebacdc4a6c2c92553604f4","0x023624c49a722bc8dc5d945b4b10be8ed6c608020e65038a470b5a407375c8aa","0x0ed9f8dd445bda548ef08b7a2ff233867c41b72786f98054597833a68cc9b900","0x2cbf3d04669aa3a0dcda95e19da879f36029abe28317f1ee69be28ddef2a0b87","0x284ca7049611e293aa4535dd7841a540996609d541814373b387b00069636f14","0x246a69ce4030b1e8a675eec89960bfe188bd4073f07afe74f7a77c0698c80bc5","0x1bbdab5d007c4743fbcbf3cc89252baf0b0e1b645b977434ccd4e7560d124761","0x210427e70ee1b484bbb0b4e98263faf24a45325236eed618d51dcb1cb3a9f60d","0x1fbc24b0bd5b0b8c514e138317cc332962714dd306b34939768d723d6ea2ca8e","0x1e74217a6bd46293e6eb721cad346b607a9d6953d677bc5a17fd195e299b9f0f","0x1d2c1e441a4db99b7c88d0b6429ca39792c984d4a63c2f7ab96cc07ee4947390","0x00000000000000000000000000000005b1e3524625c466540f3f7468172403cb","0x000000000000000000000000000000000013bb985f9d5562699347b5dfbc441e","0x000000000000000000000000000000f4fb87d7f481bb198aa6237a0c9ffd3c22","0x0000000000000000000000000000000000254c5f1b76e278f4c71cf5e71533dd","0x0000000000000000000000000000005a72a28b51be9c538b4d28b5106b9239b8","0x00000000000000000000000000000000000d02d80e1a73c82cb0dd8af1aabb3f","0x000000000000000000000000000000434c46502fc1c425a72a4717a3e44c3415","0x00000000000000000000000000000000001c8d74d967b9b65ff2772592a15d0e"] +# proof_b = ["0x0000000000000000000000000000002ab91b132e624f2a408aa8c9bf31cca8d7","0x000000000000000000000000000000000015ad57528e0f065c820cc5ad4eab81","0x0000000000000000000000000000001acb78b1b6a5c9a6ec8bf2272b463014da","0x0000000000000000000000000000000000117fd65346e04bf3666d2ab3f24c90","0x000000000000000000000000000000aad0adaf9a768ba6a178f804edac5c8943","0x000000000000000000000000000000000004a11c7d31f25c20e3af16f9b01f71","0x0000000000000000000000000000001f0ae9bb921893ce2710148eb1fcd99e39","0x0000000000000000000000000000000000123fda5008d3709f5afeda01de1930","0x000000000000000000000000000000971c2a8d0119097fd82b7a8074a14853f8","0x000000000000000000000000000000000009965b998750710678da7891d8aba6","0x0000000000000000000000000000002d6ef3813ba14a5f5202afed6b1c41de1c","0x000000000000000000000000000000000020366bfdb2f9279c43d66f90dfdf4d","0x00000000000000000000000000000041389f221eadec33e1b87518668c3bc92e","0x00000000000000000000000000000000000d3858169bb0432ab761d4be8ef03e","0x000000000000000000000000000000c1dbfe670dc912cb0fa1a0f633f81a4cef","0x00000000000000000000000000000000000fc0c403e668b0f51e07089082c32f","0x0000000000000000000000000000009a4fba9bf1369f637fd295c8bf795c9d02","0x00000000000000000000000000000000001d6d1e7286ce52401e6ea79d2cfa3d","0x0000000000000000000000000000004762bf7702ffe7a2c147e704280cd50bba","0x0000000000000000000000000000000000205797cdeaeff9a8d5ea4b95d41b1a","0x000000000000000000000000000000b3d43cc863ba8d98f51118c0db70761079","0x00000000000000000000000000000000002d2a3d10381bc6b47a693c1692b1b6","0x000000000000000000000000000000d35a69fb0e68729f71e651799c0d19e9eb","0x00000000000000000000000000000000002ade1dc7741b7f397271c10e596557","0x0000000000000000000000000000001a67b44714687085004e4142f700043298","0x00000000000000000000000000000000001bb7bbb7f45876b1d72e5d20cee106","0x00000000000000000000000000000025f1f1cbf43fad70cba255b37a19e88b0c","0x00000000000000000000000000000000000cc46b215fbd8e4b233cc74aab250b","0x0000000000000000000000000000008168026f51135fc1670664bc50e629917f","0x000000000000000000000000000000000004d822d80ba0c1bcbd4b000573c6f9","0x000000000000000000000000000000d85756249b937277eba3f5dcb89c56e7bb","0x000000000000000000000000000000000019a3a7a5b20dac138d7ddb1d499134","0x0000000000000000000000000000007621614c7ebc31a2177011f9da01668eb3","0x000000000000000000000000000000000024e9beb5d616ab120073170fc431e8","0x00000000000000000000000000000031fbf901896e958fbbed3e5c57aebbdd04","0x0000000000000000000000000000000000005ac0f10fcc255e179a40518875d4","0x0000000000000000000000000000002dab820c019bcca563b7dbdd26974653e9","0x00000000000000000000000000000000001a5655ec1a67f722b14c65d5c2197f","0x0000000000000000000000000000008e277e490196db5c19d09a9034e10c6432","0x000000000000000000000000000000000003f13b1af07db07eec88698d0aaf2a","0x0000000000000000000000000000002d618452e2b4c790d0551ea5863ed62e76","0x00000000000000000000000000000000001a7171e790a433a972d80218fb482d","0x0000000000000000000000000000005669975cd5bf65a739c0a35a8ab9b7963b","0x00000000000000000000000000000000000d27ffb6f00c86a0ce76a8067d1bce","0x03a0054fe9f93ab96e7c7ed6ec1ac641dffd99a1c804ee5db52cf1efa1a12c15","0x059324381c89c12c87d0f6c27963c31647721fdb02c125961da1a21cbfb3ed1c","0x04a5ead891b7c3f30329e6abcf2ac6903c3c1d8e68874f6baf3a6fc00e84533a","0x03c02f6b862734acf9d0c5133f8141b3a008c5499336a588b376a5dd86d9c837","0x1dd26b35c21c584c410df89d1fd549e7f5da9bb4fd290b7c528d92fbd652f5ad","0x2c8e7ef6f7a130769ae74d0f47aeab5c443492ef4b1ed0b3a9d61dfca80cbdda","0x2b074486c21c62e6eccf3191b3ab3c8df0fb98f0c44b9f0e9e2c281b908b83a6","0x149a6d620be135bba6bbfe8ac826df37567c8be78007e47cdcf5d6e4683d339e","0x119fdfd330036bde31af71e43bd5e191460605e4760d08a6e0ebddbdb5abfeeb","0x1713efc63c00b2de4f68e696d9d30c5603963484f4829e716de2796640864b09","0x1bb1862114cda3712c177b1b6bca0ecd9de7723925698aee83dc91ade7078d3e","0x049d965ad8ccf092dcae948491f702779a513db430e6ec7d15fa1847a6814235","0x093b2cb5b199e125b95d290923ee04ef34a27b6861cdd8fa2bf4308f4d02846a","0x2710c6cd6f14f8071976509d1002e915bfc182b843a3967134de380302423c72","0x24ecb2d6c6678496e574a4248fb813bcd289eda1873763e8afd0c23d340a11a8","0x298a49319f347529c22338a921af16346cdb2b55b81e5065c5cada84da8b53dd","0x2e27df8c780165bc9ed1cd2db3a618ac072c6909e9053ce2dbc4f2cc810c9612","0x07350f3a2e23c1ccbde0d39370159060de5b8df40ae7c58d3f9852b371f1adac","0x2fdf8bf8e2fa2acad0f6d6a3f73e7dc516e8e2d167128bf3a560972339122835","0x0d3ec457703c228d4b6cd1635df9d9bde51997d0228edef64d667cbd16f3cb70","0x148320b9ceab1f3be840dc38b0344e7db0755283d1eacf2dd472e99ee0fb473f","0x06febdcf4869a6b89fdeb0805612c53e139afc29d119a54bc3d72dc7de0f1a7b","0x0b9c542a2136974b7c8d4504e809c7b5adec39de020091c8d9d1460f84905cb0","0x1039ea84fa0387de593bd9897a00ca2d483d779232e77e45efcb5e572b119ee5","0x14d780dfd2d0787135ea6e0e0bf7cca4e28eb54663ce6ac305c5769ed192e11a","0x026127746f9cb625c3301bfbc41bc2c67949be75a032b8ceaddd1580378dd846","0x123cf1180af5fdf09444de423947c9a71790f2c85468b51ecc25fb7bf075a0d5","0x000000000000000000000000000000008419a4f769ceb72c3ac28f559331a5df","0x000000000000000000000000000000009e852c5c1891a89b79b64599e3d52d72","0x00000000000000000000000000000000b8f0b3c0c7549a0ab8a9fbde3478b505","0x056af493dda97ae84cdbbf9ce379e35bdd66e1223eebacdc4a6c2c92553604f4","0x023624c49a722bc8dc5d945b4b10be8ed6c608020e65038a470b5a407375c8aa","0x0ed9f8dd445bda548ef08b7a2ff233867c41b72786f98054597833a68cc9b900","0x2cbf3d04669aa3a0dcda95e19da879f36029abe28317f1ee69be28ddef2a0b87","0x284ca7049611e293aa4535dd7841a540996609d541814373b387b00069636f14","0x246a69ce4030b1e8a675eec89960bfe188bd4073f07afe74f7a77c0698c80bc5","0x1bbdab5d007c4743fbcbf3cc89252baf0b0e1b645b977434ccd4e7560d124761","0x210427e70ee1b484bbb0b4e98263faf24a45325236eed618d51dcb1cb3a9f60d","0x1fbc24b0bd5b0b8c514e138317cc332962714dd306b34939768d723d6ea2ca8e","0x1e74217a6bd46293e6eb721cad346b607a9d6953d677bc5a17fd195e299b9f0f","0x1d2c1e441a4db99b7c88d0b6429ca39792c984d4a63c2f7ab96cc07ee4947390","0x00000000000000000000000000000005b1e3524625c466540f3f7468172403cb","0x000000000000000000000000000000000013bb985f9d5562699347b5dfbc441e","0x000000000000000000000000000000f4fb87d7f481bb198aa6237a0c9ffd3c22","0x0000000000000000000000000000000000254c5f1b76e278f4c71cf5e71533dd","0x0000000000000000000000000000005a72a28b51be9c538b4d28b5106b9239b8","0x00000000000000000000000000000000000d02d80e1a73c82cb0dd8af1aabb3f","0x000000000000000000000000000000434c46502fc1c425a72a4717a3e44c3415","0x00000000000000000000000000000000001c8d74d967b9b65ff2772592a15d0e"] key_hash = "0x096129b1c6e108252fc5c829c4cc9b7e8f0d1fd9f29c2532b563d6396645e08f" -proof = ["0x0000000000000000000000000000000000000000000000000000000000000003","0x000000000000000000000000000000d62b795bec274279129a71195796825fcc","0x00000000000000000000000000000000000793ab763140f20a68a6bd2721fd74","0x00000000000000000000000000000053141d06d3307b36153f321511199e579c","0x00000000000000000000000000000000000a4b55d6c21f98a9c434911dcb5c67","0x0000000000000000000000000000005f9d324c0abd22cec92d99dbec438e9491","0x0000000000000000000000000000000000240dfafe1b53dc27147cbab14ea893","0x000000000000000000000000000000044a61d3aac32c6931247cf334a19d9611","0x000000000000000000000000000000000003f0f8cf4207bfa85c23ec9f8d0c88","0x00000000000000000000000000000002168a470e39ba2ac266f6b474de12045f","0x000000000000000000000000000000000025791e7d3feab542345c00ec5a30df","0x000000000000000000000000000000dcafd76d4c3640969c80e017b951ef6397","0x00000000000000000000000000000000001d27f75a1256771e88e0c86fc42dbc","0x0000000000000000000000000000007347ae7d2d9d7fc2b8f0baa014ee1fed9f","0x000000000000000000000000000000000018bd927f42bf7caf9555f56f09000d","0x000000000000000000000000000000041f765f83cbe5904c8f453f70a4531d10","0x00000000000000000000000000000000001858aabeeb5331a221419f4fed1c19","0x000000000000000000000000000000d254a54caaedf8287b9af951b2f2611121","0x000000000000000000000000000000000005ab493623c9563cf2e55ba5f18200","0x00000000000000000000000000000014f24cddc1a02440dc63637df8032c8074","0x000000000000000000000000000000000011950c16cef98471b1d78b935195a4","0x000000000000000000000000000000b0340b459e6bd5cc8f031c8654a502897f","0x00000000000000000000000000000000000e1cf3968dac4545a76a2ae58e512c","0x0000000000000000000000000000002adf7218aa06ca0d2c2e600dcc39193a2d","0x00000000000000000000000000000000001302e7e4b0f14749bd885ca25588b6","0x00000000000000000000000000000092009ce4056e79ab815d8cdfd4491138ae","0x000000000000000000000000000000000018af11e853c6cf2f0f6274b0da8133","0x000000000000000000000000000000dd3dc6f49232141718527b3a0e4b26e21d","0x00000000000000000000000000000000001a877853348a8b695c4f9a9aa4ce68","0x000000000000000000000000000000aecfc56ba07155450b368140d6324023b5","0x000000000000000000000000000000000029c11052798c57ece614617d33fcc2","0x000000000000000000000000000000eb106ffc816d16fb84e84b0b61157b2603","0x000000000000000000000000000000000026c3cac16206899a21cb5126841446","0x000000000000000000000000000000a782ed54805fe845068b362b58e2fa34ec","0x00000000000000000000000000000000000cf046a1bfcc666b7f28b572676073","0x000000000000000000000000000000b931c8dda60bb4aca4cc817f5540f1209f","0x000000000000000000000000000000000024ad50c3936fafc3d190e6a4874223","0x000000000000000000000000000000cce90cfbaf5671c8c8652db28a3a9566f7","0x000000000000000000000000000000000003574db9d0f84380c9635660f86354","0x0000000000000000000000000000003eb3e1dc31846a90f721e7a08c6d6dc4f7","0x000000000000000000000000000000000028999a700cd1abae1a288eebb9a91c","0x000000000000000000000000000000c1be4d385b11387e14eb9817050d772f78","0x000000000000000000000000000000000003c56b5bad8b4484c66ac921f1f102","0x000000000000000000000000000000ace245cabf0f00dc7fd253dd8af0377a14","0x0000000000000000000000000000000000107f1731fcf34b364c813599fa1df7","0x035b937d404932b542b706eb810ef4a7dca4566d4dde1ad6a8717f46167ead7e","0x17608cef3dc7960f41cb1295706df663727d45ee598a61e05e989d111449fb65","0x054712a950ad67da3aa860e49e6891f99b586b7f37caff94eb013fdb374b61ee","0x04b755083086c769b7f593e0e48d68dc54be808203351380ca5566a48149d8bb","0x17d7670b0915235f626fdc1d7e1134d2be906ef138d7843384b3ebc23b1d630f","0x064cf544ab5f4e3dab47960502cccc83321fb275068dfbdd3a2fcbc6dddcaa65","0x083338262712e2b66769ea40d9f412b18caa1bc81a51ff5a50b6c41f8c4b3d23","0x0cdd38958cab97defde00f4a5961b6fd676e29d9f2c352f6bb2c68b91f83f8af","0x02c8bdd005c2f43a0a8cbb2744916ce5c322dfa5b23367a829c12699f4036d32","0x25bac73c7e7b659fbea3135b7a0decf9db8dc3045bd2837dae337c64cc722546","0x19eb361aa419d37bce3d2e8b2b7692a02a9559e83d7f3d8fe9169970fbbc2cba","0x2494bd5106d00e05c7ea60e632e9fe03773b7f2c5b662aa37ec512a01f4a0775","0x18c52c2f2c6e7be1d7847c15e452a3a9c64316103d12e4b5b9a82fac4e940ee9","0x0e0342810456ef78f498c1bfa085a5f3cbc06db1f32fabd0ea9ad27dccac1680","0x024c13d6ef56af33ed7164ea8e47ddecc8a487b000d8b1b45edcd3895a503ba2","0x26e0d127f626bd39b55bc5d0c131dbf03fe006dc5c3edc57dda1e629799a4317","0x1b1140061bc52b15c4f5e100729a81968ee79dc03deb966a18850335a8e44a8b","0x1bb76f945199e71d531a89288912087a02dd0e83020e65d671485bf2e5e86e1a","0x29269900859c6d86e404185b415bf3b279cd100f38cfdb0077e8d6a299c4fd35","0x22b5e94bae2f6f0cdb424a3b12c4bf82cec3fb228e012c1974ed457827bbe012","0x18d3543a93249778e7a57936170dae85ffc47c2567f2d0076a32c0bb86fcf10a","0x03721dc2670206cde42a175fd56bcce32cf6cb8801450a8e8e4b3d4e07785973","0x2806db136dd214d3ac1478460855cae6a4324ab45cab35320d104fee26c260e8","0x1c3749f1937082afbbae9375b9be708cf339e1983e57ef4447f36cfa560c685c","0x1067b8cfb90ef08bcb48aea56b2716334241787c2004a95682d68a0685566fd0","0x0f41aee4416398f1d48ffc302403273cddef34a41f98507c53682041d82e51ff","0x10d854c9f0bfbdff7ca91a68f4978e9a79e7b14243d92f465f17bdf88d9f64f8","0x00000000000000000000000000000000018938b11099e0cdc05ddab84a153a97","0x0000000000000000000000000000000001d7dda1471f0dc3b3a3d3438c197982","0x00000000000000000000000000000000022682917da43ab9a6e9cbcece1db86d","0x2453913e6b0f36eab883ac4b0e0604d56aaeb9c55e641135173e63c342f1a660","0x05216c1b58dc43a49d01aaba3113b0e86be450fc17d28016e648e7162a1b67fb","0x152b34845a0222a2b41354c0d395a250d8363dc18748647d85acd89d6934ec56","0x1dfc6e971ce82b7dcda1f7f282713c6e22a8c79258a61209bda69719806da544","0x2968dd8b3af8e3953f1fbbd72f4c49b8270597bb27d4037adc157ac6083bee60","0x1b9425b88a4c7d39b3d75afe66917a9aa1d2055724392bc01fb918d84ff1410e","0x04ab571f236d8e750904dc307dd274003d9130f1a7110e4c1521cfb408877c73","0x2ad84f26fdc5831545272d02b806bb0e6dae44e71f73552c4eb9ff06030748c7","0x020e632b99d325db774b8630fb50b9a4e74d35b7f27d9fc02c65087ee747e42c","0x09a8c5a3171268cb61c02515c01c109889200ed13f415ae54df2078bbb887f92","0x1143281a9451abbb4c34c3fa84e7678c2af2e7ea8c05160a6f7f06988fc91af8","0x000000000000000000000000000000cbda736ca5cf6bc75413c2cc9e28ab0a68","0x00000000000000000000000000000000001ee78c9cc56aa5991062ae2e338587","0x000000000000000000000000000000bc9bfcdebb486f4cb314e681d2cc5f8df6","0x00000000000000000000000000000000000ad538431d04771bca7f633cb659ff","0x000000000000000000000000000000d45b317afcefa466a59bba9e171f1af70c","0x0000000000000000000000000000000000133c50180ea17932e4881124e7a7c6","0x000000000000000000000000000000fc9ed37f543775849f3e84eaa06f77f992","0x00000000000000000000000000000000001372873c9c051d1baff99248b8f70e"] +proof = ["0x000000000000000000000000000000d62b795bec274279129a71195796825fcc","0x00000000000000000000000000000000000793ab763140f20a68a6bd2721fd74","0x00000000000000000000000000000053141d06d3307b36153f321511199e579c","0x00000000000000000000000000000000000a4b55d6c21f98a9c434911dcb5c67","0x0000000000000000000000000000005f9d324c0abd22cec92d99dbec438e9491","0x0000000000000000000000000000000000240dfafe1b53dc27147cbab14ea893","0x000000000000000000000000000000044a61d3aac32c6931247cf334a19d9611","0x000000000000000000000000000000000003f0f8cf4207bfa85c23ec9f8d0c88","0x00000000000000000000000000000002168a470e39ba2ac266f6b474de12045f","0x000000000000000000000000000000000025791e7d3feab542345c00ec5a30df","0x000000000000000000000000000000dcafd76d4c3640969c80e017b951ef6397","0x00000000000000000000000000000000001d27f75a1256771e88e0c86fc42dbc","0x0000000000000000000000000000007347ae7d2d9d7fc2b8f0baa014ee1fed9f","0x000000000000000000000000000000000018bd927f42bf7caf9555f56f09000d","0x000000000000000000000000000000041f765f83cbe5904c8f453f70a4531d10","0x00000000000000000000000000000000001858aabeeb5331a221419f4fed1c19","0x000000000000000000000000000000d254a54caaedf8287b9af951b2f2611121","0x000000000000000000000000000000000005ab493623c9563cf2e55ba5f18200","0x00000000000000000000000000000014f24cddc1a02440dc63637df8032c8074","0x000000000000000000000000000000000011950c16cef98471b1d78b935195a4","0x000000000000000000000000000000b0340b459e6bd5cc8f031c8654a502897f","0x00000000000000000000000000000000000e1cf3968dac4545a76a2ae58e512c","0x0000000000000000000000000000002adf7218aa06ca0d2c2e600dcc39193a2d","0x00000000000000000000000000000000001302e7e4b0f14749bd885ca25588b6","0x00000000000000000000000000000092009ce4056e79ab815d8cdfd4491138ae","0x000000000000000000000000000000000018af11e853c6cf2f0f6274b0da8133","0x000000000000000000000000000000dd3dc6f49232141718527b3a0e4b26e21d","0x00000000000000000000000000000000001a877853348a8b695c4f9a9aa4ce68","0x000000000000000000000000000000aecfc56ba07155450b368140d6324023b5","0x000000000000000000000000000000000029c11052798c57ece614617d33fcc2","0x000000000000000000000000000000eb106ffc816d16fb84e84b0b61157b2603","0x000000000000000000000000000000000026c3cac16206899a21cb5126841446","0x000000000000000000000000000000a782ed54805fe845068b362b58e2fa34ec","0x00000000000000000000000000000000000cf046a1bfcc666b7f28b572676073","0x000000000000000000000000000000b931c8dda60bb4aca4cc817f5540f1209f","0x000000000000000000000000000000000024ad50c3936fafc3d190e6a4874223","0x000000000000000000000000000000cce90cfbaf5671c8c8652db28a3a9566f7","0x000000000000000000000000000000000003574db9d0f84380c9635660f86354","0x0000000000000000000000000000003eb3e1dc31846a90f721e7a08c6d6dc4f7","0x000000000000000000000000000000000028999a700cd1abae1a288eebb9a91c","0x000000000000000000000000000000c1be4d385b11387e14eb9817050d772f78","0x000000000000000000000000000000000003c56b5bad8b4484c66ac921f1f102","0x000000000000000000000000000000ace245cabf0f00dc7fd253dd8af0377a14","0x0000000000000000000000000000000000107f1731fcf34b364c813599fa1df7","0x035b937d404932b542b706eb810ef4a7dca4566d4dde1ad6a8717f46167ead7e","0x17608cef3dc7960f41cb1295706df663727d45ee598a61e05e989d111449fb65","0x054712a950ad67da3aa860e49e6891f99b586b7f37caff94eb013fdb374b61ee","0x04b755083086c769b7f593e0e48d68dc54be808203351380ca5566a48149d8bb","0x17d7670b0915235f626fdc1d7e1134d2be906ef138d7843384b3ebc23b1d630f","0x064cf544ab5f4e3dab47960502cccc83321fb275068dfbdd3a2fcbc6dddcaa65","0x083338262712e2b66769ea40d9f412b18caa1bc81a51ff5a50b6c41f8c4b3d23","0x0cdd38958cab97defde00f4a5961b6fd676e29d9f2c352f6bb2c68b91f83f8af","0x02c8bdd005c2f43a0a8cbb2744916ce5c322dfa5b23367a829c12699f4036d32","0x25bac73c7e7b659fbea3135b7a0decf9db8dc3045bd2837dae337c64cc722546","0x19eb361aa419d37bce3d2e8b2b7692a02a9559e83d7f3d8fe9169970fbbc2cba","0x2494bd5106d00e05c7ea60e632e9fe03773b7f2c5b662aa37ec512a01f4a0775","0x18c52c2f2c6e7be1d7847c15e452a3a9c64316103d12e4b5b9a82fac4e940ee9","0x0e0342810456ef78f498c1bfa085a5f3cbc06db1f32fabd0ea9ad27dccac1680","0x024c13d6ef56af33ed7164ea8e47ddecc8a487b000d8b1b45edcd3895a503ba2","0x26e0d127f626bd39b55bc5d0c131dbf03fe006dc5c3edc57dda1e629799a4317","0x1b1140061bc52b15c4f5e100729a81968ee79dc03deb966a18850335a8e44a8b","0x1bb76f945199e71d531a89288912087a02dd0e83020e65d671485bf2e5e86e1a","0x29269900859c6d86e404185b415bf3b279cd100f38cfdb0077e8d6a299c4fd35","0x22b5e94bae2f6f0cdb424a3b12c4bf82cec3fb228e012c1974ed457827bbe012","0x18d3543a93249778e7a57936170dae85ffc47c2567f2d0076a32c0bb86fcf10a","0x03721dc2670206cde42a175fd56bcce32cf6cb8801450a8e8e4b3d4e07785973","0x2806db136dd214d3ac1478460855cae6a4324ab45cab35320d104fee26c260e8","0x1c3749f1937082afbbae9375b9be708cf339e1983e57ef4447f36cfa560c685c","0x1067b8cfb90ef08bcb48aea56b2716334241787c2004a95682d68a0685566fd0","0x0f41aee4416398f1d48ffc302403273cddef34a41f98507c53682041d82e51ff","0x10d854c9f0bfbdff7ca91a68f4978e9a79e7b14243d92f465f17bdf88d9f64f8","0x00000000000000000000000000000000018938b11099e0cdc05ddab84a153a97","0x0000000000000000000000000000000001d7dda1471f0dc3b3a3d3438c197982","0x00000000000000000000000000000000022682917da43ab9a6e9cbcece1db86d","0x2453913e6b0f36eab883ac4b0e0604d56aaeb9c55e641135173e63c342f1a660","0x05216c1b58dc43a49d01aaba3113b0e86be450fc17d28016e648e7162a1b67fb","0x152b34845a0222a2b41354c0d395a250d8363dc18748647d85acd89d6934ec56","0x1dfc6e971ce82b7dcda1f7f282713c6e22a8c79258a61209bda69719806da544","0x2968dd8b3af8e3953f1fbbd72f4c49b8270597bb27d4037adc157ac6083bee60","0x1b9425b88a4c7d39b3d75afe66917a9aa1d2055724392bc01fb918d84ff1410e","0x04ab571f236d8e750904dc307dd274003d9130f1a7110e4c1521cfb408877c73","0x2ad84f26fdc5831545272d02b806bb0e6dae44e71f73552c4eb9ff06030748c7","0x020e632b99d325db774b8630fb50b9a4e74d35b7f27d9fc02c65087ee747e42c","0x09a8c5a3171268cb61c02515c01c109889200ed13f415ae54df2078bbb887f92","0x1143281a9451abbb4c34c3fa84e7678c2af2e7ea8c05160a6f7f06988fc91af8","0x000000000000000000000000000000cbda736ca5cf6bc75413c2cc9e28ab0a68","0x00000000000000000000000000000000001ee78c9cc56aa5991062ae2e338587","0x000000000000000000000000000000bc9bfcdebb486f4cb314e681d2cc5f8df6","0x00000000000000000000000000000000000ad538431d04771bca7f633cb659ff","0x000000000000000000000000000000d45b317afcefa466a59bba9e171f1af70c","0x0000000000000000000000000000000000133c50180ea17932e4881124e7a7c6","0x000000000000000000000000000000fc9ed37f543775849f3e84eaa06f77f992","0x00000000000000000000000000000000001372873c9c051d1baff99248b8f70e"] public_inputs = ["0x0000000000000000000000000000000000000000000000000000000000000003"] verification_key = ["0x2b337de1c8c14f22ec9b9e2f96afef3652627366f8170a0a948dad4ac1bd5e80","0x0000000000000000000000000000000000000000000000000000000000000008","0x0000000000000000000000000000000000000000000000000000000000000005","0x0000000000000000000000000000000000000000000000000000000000000008","0x0000000000000000000000000000000000000000000000000000000000000001","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x0000000000000000000000000000000000000000000000000000000000000000","0x00000000000000000000000000000092139c61bae1a44f0fc7689507414be688","0x00000000000000000000000000000000000160ce4e279582f91bde4f03f5e9a2","0x0000000000000000000000000000005dc2d37f658c3b2d60f24740eb13b65d79","0x000000000000000000000000000000000007e3e8a5d98a1177ec85bf88f163a5","0x000000000000000000000000000000dc3035fbd7ff16412a8fd7da587a935298","0x000000000000000000000000000000000023d08e2817ac16990004ed11d8fc66","0x000000000000000000000000000000356a5ad59c646c746a8d09f5d154e47c4f","0x00000000000000000000000000000000000708529196af3c8e16ffa580c26182","0x0000000000000000000000000000002ddfe70eb7a1280596e8e4a804f118a6dd","0x000000000000000000000000000000000013757e15a0905f298303784a161b21","0x000000000000000000000000000000a23a729df796935c7824e3a26be794829b","0x000000000000000000000000000000000005775b6c146c4a59856e869fe5a70e","0x000000000000000000000000000000eef0c9e088fd2d45aa40311082d1f2809b","0x00000000000000000000000000000000001d539ccbfc556d0ad59307a218de65","0x000000000000000000000000000000a2c848beceb6ab7806fd3b88037b8410fc","0x0000000000000000000000000000000000177004deeb1f9d401fd7b1af1a5ac8","0x0000000000000000000000000000002508eb63672a733f20de1a97644be4f540","0x00000000000000000000000000000000000d82d51f2f75d806285fd248c819b8","0x000000000000000000000000000000d002f9100cbba8a29f13b11513c53c59d0","0x000000000000000000000000000000000006cd3b0e3460533b9e5ea2cdc0fcbb","0x000000000000000000000000000000f45ea38a93b2f810c5633ddb54927c1c96","0x000000000000000000000000000000000021791de65f9a28ec7024b1a87ab4f3","0x000000000000000000000000000000926511a0439502c86885a8c6f0327aa7ad","0x000000000000000000000000000000000029fa14a969c5d81ed3abbbfb11220a","0x000000000000000000000000000000b84c3258e8206f560e5b5b18cbeafef87e","0x00000000000000000000000000000000002a910445cd8fc895e5d235cd8ea185","0x000000000000000000000000000000887e67f15e84bcb8507a5064a363f6043b","0x000000000000000000000000000000000014dc6643d801c3ef27c2066b6e2bb4","0x000000000000000000000000000000e38e900b42c314ba803088e8fbf125203f","0x000000000000000000000000000000000020690fd4869db418306046b38161dc","0x0000000000000000000000000000001e2fa856bf7951b8292b1e88185993629c","0x0000000000000000000000000000000000048a85e0bbac7c60ad3d78f601f63c","0x0000000000000000000000000000006f457719495073d3666d77a625aeab0c51","0x00000000000000000000000000000000002623ad892dc62b1fa7d0a650f0d470","0x000000000000000000000000000000dbfcc8a467e021c03b13f74a9f79c3a10c","0x0000000000000000000000000000000000295f6f10976c37bd9c6f96bb7187d5","0x000000000000000000000000000000c13ef9a937cc12420fb38d9ab8e848e85e","0x000000000000000000000000000000000003560a3b334e887532f605c9cb7628","0x0000000000000000000000000000009bcebf08a4599cdda0fb96312d4dc0c7a9","0x000000000000000000000000000000000015adc8bb1e01c835f48959d1237bd6","0x00000000000000000000000000000047762ab839e4ff63c77605a9f383da37c2","0x000000000000000000000000000000000016a8c3c53d89660cf271522cd301fb","0x000000000000000000000000000000f0c8539a0b5f94420a513f9c305b932bfe","0x00000000000000000000000000000000002957ba01d9de5638f808f88a692533","0x000000000000000000000000000000ab17c6189d67d3bf5dd2f3885de0151b6f","0x0000000000000000000000000000000000060d8aa43fdc434d1942263f364d95","0x0000000000000000000000000000005d292333b3adb497f00b4bc32d45229060","0x00000000000000000000000000000000001a1018a66221883639f2898a66f345","0x00000000000000000000000000000006555a806b1993291deba0dc44e2abf431","0x00000000000000000000000000000000000cacff7099a9d5e35a21f4a00b2dc3","0x000000000000000000000000000000f50c11ba95d349c36d143eefd12e494950","0x00000000000000000000000000000000001022e8c5f02d639bc9dd8bc4407f99","0x000000000000000000000000000000c76828795098eda73d50b4b585c60afc60","0x00000000000000000000000000000000002bf09c0ec7011e93888962f2406630","0x00000000000000000000000000000049e5c83a8978d832fb8e144548e3ca1adb","0x00000000000000000000000000000000000e0ec242c2e160a984f61ca5adf5f5","0x0000000000000000000000000000009c5d6e08a6605ab4513748ac0fa017dd1c","0x00000000000000000000000000000000001f54baa07558e5fb055bd9ba49c067","0x0000000000000000000000000000001e1ee7ee29bbb5e4b080c6091c1433ce62","0x000000000000000000000000000000000024aec62a9d9763499267dc98c33428","0x0000000000000000000000000000001a96755946ff16f0d6632365f0eb0ab4d4","0x000000000000000000000000000000000028cf3e22bcd53782ebc3e0490e27e5","0x00000000000000000000000000000043148d7d8c9ba43f2133fab4201435a364","0x0000000000000000000000000000000000234ce541f1f5117dd404cfaf01a229","0x000000000000000000000000000000a7fb95ffb461d9514a1070e2d2403982ef","0x00000000000000000000000000000000003016955028b6390f446c3fd0c5b424","0x00000000000000000000000000000008863c3b7cd7cddc20ba79ce915051c56e","0x000000000000000000000000000000000013ef666111b0be56a235983d397d2a","0x000000000000000000000000000000e3993f465fc9f56e93ac769e597b752c1c","0x0000000000000000000000000000000000217f7c4235161e9a3c16c45b6ca499","0x0000000000000000000000000000008ffa4cd96bc67b0b7df5678271e1114075","0x0000000000000000000000000000000000256467bfcb63d9fdcb5dde397757ad","0x00000000000000000000000000000054e5eb270bb64bde6e6ececadfd8c3236c","0x00000000000000000000000000000000000e52d1bd75812c33c6f3d79ee4b94c","0x000000000000000000000000000000484a2c641dce55bc2dd64ef0cd790a7fea","0x00000000000000000000000000000000000ff417d256be43e73c8b1aa85bdda3","0x0000000000000000000000000000000b72e7b7713ab5da44e0f864182e748a23","0x00000000000000000000000000000000001a221055f1625ad833a44705f5f74e","0x00000000000000000000000000000067a99a34e9b81a17ad001db02e29bcb82a","0x000000000000000000000000000000000018a6c02e398389827568fa960e86e2","0x000000000000000000000000000000bb29f26f9890d6cc6401f4921d5884edca","0x00000000000000000000000000000000000868357b28039385c5a5058b6d358e","0x00000000000000000000000000000036fb6e229dde8edf7ec858b12d7e8be485","0x00000000000000000000000000000000001060afe929554ca473103f5e68193c","0x00000000000000000000000000000015226e07e207744c0857074dcab883af4a","0x00000000000000000000000000000000000b1c02619282755533457230b19b4a","0x0000000000000000000000000000001f2a0277e4807e6e1cbabca21dde5eb5e1","0x00000000000000000000000000000000000d928deafed363659688ed4ccdef52","0x000000000000000000000000000000363f0c994e91cecad25835338edee2294f","0x00000000000000000000000000000000002eea648c8732596b1314fe2a4d2f05","0x000000000000000000000000000000b2671d2ae51d31c1210433c3972bb64578","0x00000000000000000000000000000000000ab49886c2b94bd0bd3f6ed1dbbe2c"] -proof_b = ["0x0000000000000000000000000000000000000000000000000000000000000003","0x000000000000000000000000000000f05c69448ca29bdf52076f9b073bb30fed","0x000000000000000000000000000000000028c86bb3e27b4aaaaef126f7df5349","0x00000000000000000000000000000026ae031fc93594375dfc7f3bbe027f97d5","0x000000000000000000000000000000000000dd12c7290fe7f775796a233b8590","0x000000000000000000000000000000c1ee6631704de424d010c5c4ac8293ac49","0x00000000000000000000000000000000002f41818c9aa83f5c8d9bdd128015b9","0x000000000000000000000000000000b50a5801482f7e3a5de8ab3cce0f10b0d3","0x000000000000000000000000000000000022a0bc69c293dbf293b25bc9eef7f8","0x0000000000000000000000000000003b02abf1967ef394154dc15d763135e903","0x00000000000000000000000000000000000d8a2ee46acc6d1ed8d517b56d47c8","0x00000000000000000000000000000039bf0d1b3d8cf9de898f101c626e978d78","0x0000000000000000000000000000000000008faa7df2451a24d291a9b584f1a5","0x000000000000000000000000000000c1dae329ed7adf63a2d89a5f16fb98b6d8","0x00000000000000000000000000000000001ff0bc16fc0bd4aa2d6255690453c2","0x000000000000000000000000000000d12d7589f853a9b472613efa56689beaf1","0x00000000000000000000000000000000002d6fbc798f4403751df6aeee8bedd3","0x0000000000000000000000000000007c1fa069cb17194fecf88db9dd54a4ee36","0x0000000000000000000000000000000000268e026f9814822a42b2d59eec5d24","0x000000000000000000000000000000c3fb56beab774218cd63498fc050a5fd9b","0x00000000000000000000000000000000000071c014d7b5063f005a0bc2ee1af4","0x000000000000000000000000000000ae12b25371c6af42bbe0a85cddd2eaebc7","0x000000000000000000000000000000000026d270e1ffc9c7c344c694dfadda83","0x00000000000000000000000000000080280858c6be461716921caa3c26f3f6f3","0x000000000000000000000000000000000001dcdd3f39e27d0ce6aa5d14dff4c1","0x000000000000000000000000000000080e1d2c913c834ebcf7e0600c076c08fd","0x00000000000000000000000000000000002df3d142217694e65fb7c355d62764","0x000000000000000000000000000000e5e336f3f59d77e500f49771bfbeb12e83","0x000000000000000000000000000000000028fffe08bdc4c0690643d2e1a1275f","0x000000000000000000000000000000db5618b32afc13e18f21b39f3fbede9d11","0x00000000000000000000000000000000001d244818370d43fb7e8bc67e03787b","0x0000000000000000000000000000006bcc1fd3f9f78449ad1df1bc11bc379edd","0x000000000000000000000000000000000009ac9cbb285edbf5b3a973f3f5f1cb","0x000000000000000000000000000000fd885905b6c0fc95bb4dd0b11f6797d4b3","0x000000000000000000000000000000000021f07995cdd835145e19c38127c562","0x000000000000000000000000000000bbbf2b975c2c97ae4b45c4a52059e53ee3","0x000000000000000000000000000000000024158163788841cf4590bbc1e89a90","0x0000000000000000000000000000009aca93d2b1386ea412d4b36ea5bb9894a8","0x00000000000000000000000000000000002532d1d210e8ed4c2f5c00cbaaa475","0x000000000000000000000000000000634a88caa1d77cb6b5fe77cac31458fc31","0x00000000000000000000000000000000000bdf18bae92fce7cfddab5520cac6e","0x000000000000000000000000000000622e9626255170ccec77602c755aa193e1","0x000000000000000000000000000000000001d4edba370e04436a988bad05dada","0x000000000000000000000000000000b52934323a0aec8f803cdaafee2ab7bfb2","0x0000000000000000000000000000000000155312af5e0e25ca9fd61aef9e58ed","0x06270b517855f6f6a608e432883d1d1030a12a1e33022dc142b7728691421da2","0x2af7c794d7b720b25eb1df0afd8c8e3c15b6e518194c3caea7966a5f8210ff04","0x073fe573aeb27d81a5713be93e1365390dcbc3c8e7439ff1d36a84cc014f5642","0x11351b961147431e54535248b58b35cf5cddb9b13827899167617d7a96794d64","0x297c9421c9c3db286770787c35b86bc41583386491b4ae55e5fa81aefa21efc4","0x0f4eeca3ff4a3495f859898937688652d33f9b4dd3e003e12adf15278e0997c3","0x133e3d8b82721d40d919f2326810ba6f07eff3f7d20d86b2bde692a811522019","0x2c502f53c9698b73bb8c8f9b9cf2d705d16a64a7040348b4b39c637a2064316c","0x0cbc1971e1c566cde9d9125c91cdc88e817db182692f836c1a5170a6246eaf73","0x12c47793e7db706c637cd4b4d96d227f569850176b852b1fe8ad522ddb38ef0e","0x0cd7b300e9309a135285be1aeb02b152f97931a7357ab6d609a2cb1970aab877","0x2a7789dfe286c9d0a7592f1c9316e730cb14c9d843aefc4764d76e7f8571c96a","0x248ac54ce3dbf37796621882a4ac76046df5ab680da487fd85cce76b1ae392d3","0x149d1d07cebe320f77b03533e34912545cedeae62bd9778d37724728762b5710","0x00fe29daebdaed61309790e70e2dcefa3f3af4c6c965ce424b8dbcf09b8e4b49","0x2b75b3bace61b731d7f0c003a144b62b0a4fbe9f0d14ca89b0652b70210014b3","0x2588ef27cfb6e0d8c6f9a969b2da44fead30a02ed70a563fd15aa45bb671de1c","0x2b74d7674b55642697b4a1e226eddb0e4918b2d57aa5b99093dc46cadcdea000","0x244c626845d3a5040f08f01e9611f968ad675ca857789149b13a0cfa83a2e064","0x2cb8d02f90cae33fd7bcfb80af4aff067c4f5fc4b3f9228d5b8f768bc8f6c971","0x1372f3d1f04e0c39a50e823d5da03d70bebe19a1b8e28f8c2ff601cc0bfc0095","0x19af6601d2613426a50b7c35d60562a5f2f2634e6af56dac13459632e15570ee","0x13c2a16ed3b65dcd9414659be79af17995d344de34eaf962343b0f1e76c73a57","0x0dd5dcdbd50b8774831d4f01f930804d38b4266dfee085185530880a0c3903c0","0x07e91848d660b11b722638680ac60f20db9507fdc8d610ce762600f5a1aacd29","0x1f9c2a94d10c0a7fb60292cfc46fd3d2501181bea0ffe1f5f2501d474be3a785","0x14edb9c5bd389eae08a5ea2a7a1662894e1e878c142084d966a625bef68cf7c3","0x00000000000000000000000000000000cecd01810814d175f0a533f0067618c4","0x00000000000000000000000000000000f82935013ce5c82720c63e533af41db8","0x000000000000000000000000000000012185688171b6bed850e748b66f7222ac","0x2dd7f5ff2150155c2ac86ebe28d9ecbca2eea812b0021ab2bceae111cfea8325","0x04ea6c2daf2b9e827d2213c3d03953410dcf1ed67ba34a3c00e772be92606a8b","0x163f2bd18dcde52f99b9867c944780fd718d1612927053b139b280fc55013d1b","0x05e388fd160ccac30a8f7b18a4bd042f705e92b5937e8c0e9478e2ff623907c6","0x00ba3f6f527d6ed3ff17a63b1d5be3c42bdfae88fdf63311fc7b871157939309","0x16187d9daa8c2e5a1a9ab15be7ca6a8feebfb31bea76f9a3ca69381881c70561","0x0f64522e4904edb7377b14a7b9dad848829167324ef5c016346b3ad8251191ee","0x273bbe6000a4001dce369e5a36cc0b0ca3fd351665b688238aa8c556a6ca6b8e","0x022d2232efb2faa8307846c9a4c697aabad1b7f1336b35ad72fa8922975b49d9","0x0d82d478bff3955c4b0a34ef94427ca5f9da23147ad953c89f2e428277ec2825","0x18d886be90343010659c231583be61a138e28e37c24771e3cb61fbe2587d0671","0x000000000000000000000000000000196ba6a58dbeb7c34cb1d6287e23d434de","0x00000000000000000000000000000000001df8ae8a1589590f8863c1fefd8dfd","0x000000000000000000000000000000f30e11b2c5fbefa166cbb9f58c5f8e1a4c","0x000000000000000000000000000000000026420ade7666bc0ab1cf1fd9d0c534","0x0000000000000000000000000000000feb5b7d8260d25a1ee1ce76ff461673fc","0x00000000000000000000000000000000002bd2ac6223a80671b777bf5dca70a4","0x000000000000000000000000000000690f757006d2fa1ddb0114c9f268783537","0x000000000000000000000000000000000023ad36feadd91e50118f32e97a0204"] \ No newline at end of file +proof_b = ["0x000000000000000000000000000000f05c69448ca29bdf52076f9b073bb30fed","0x000000000000000000000000000000000028c86bb3e27b4aaaaef126f7df5349","0x00000000000000000000000000000026ae031fc93594375dfc7f3bbe027f97d5","0x000000000000000000000000000000000000dd12c7290fe7f775796a233b8590","0x000000000000000000000000000000c1ee6631704de424d010c5c4ac8293ac49","0x00000000000000000000000000000000002f41818c9aa83f5c8d9bdd128015b9","0x000000000000000000000000000000b50a5801482f7e3a5de8ab3cce0f10b0d3","0x000000000000000000000000000000000022a0bc69c293dbf293b25bc9eef7f8","0x0000000000000000000000000000003b02abf1967ef394154dc15d763135e903","0x00000000000000000000000000000000000d8a2ee46acc6d1ed8d517b56d47c8","0x00000000000000000000000000000039bf0d1b3d8cf9de898f101c626e978d78","0x0000000000000000000000000000000000008faa7df2451a24d291a9b584f1a5","0x000000000000000000000000000000c1dae329ed7adf63a2d89a5f16fb98b6d8","0x00000000000000000000000000000000001ff0bc16fc0bd4aa2d6255690453c2","0x000000000000000000000000000000d12d7589f853a9b472613efa56689beaf1","0x00000000000000000000000000000000002d6fbc798f4403751df6aeee8bedd3","0x0000000000000000000000000000007c1fa069cb17194fecf88db9dd54a4ee36","0x0000000000000000000000000000000000268e026f9814822a42b2d59eec5d24","0x000000000000000000000000000000c3fb56beab774218cd63498fc050a5fd9b","0x00000000000000000000000000000000000071c014d7b5063f005a0bc2ee1af4","0x000000000000000000000000000000ae12b25371c6af42bbe0a85cddd2eaebc7","0x000000000000000000000000000000000026d270e1ffc9c7c344c694dfadda83","0x00000000000000000000000000000080280858c6be461716921caa3c26f3f6f3","0x000000000000000000000000000000000001dcdd3f39e27d0ce6aa5d14dff4c1","0x000000000000000000000000000000080e1d2c913c834ebcf7e0600c076c08fd","0x00000000000000000000000000000000002df3d142217694e65fb7c355d62764","0x000000000000000000000000000000e5e336f3f59d77e500f49771bfbeb12e83","0x000000000000000000000000000000000028fffe08bdc4c0690643d2e1a1275f","0x000000000000000000000000000000db5618b32afc13e18f21b39f3fbede9d11","0x00000000000000000000000000000000001d244818370d43fb7e8bc67e03787b","0x0000000000000000000000000000006bcc1fd3f9f78449ad1df1bc11bc379edd","0x000000000000000000000000000000000009ac9cbb285edbf5b3a973f3f5f1cb","0x000000000000000000000000000000fd885905b6c0fc95bb4dd0b11f6797d4b3","0x000000000000000000000000000000000021f07995cdd835145e19c38127c562","0x000000000000000000000000000000bbbf2b975c2c97ae4b45c4a52059e53ee3","0x000000000000000000000000000000000024158163788841cf4590bbc1e89a90","0x0000000000000000000000000000009aca93d2b1386ea412d4b36ea5bb9894a8","0x00000000000000000000000000000000002532d1d210e8ed4c2f5c00cbaaa475","0x000000000000000000000000000000634a88caa1d77cb6b5fe77cac31458fc31","0x00000000000000000000000000000000000bdf18bae92fce7cfddab5520cac6e","0x000000000000000000000000000000622e9626255170ccec77602c755aa193e1","0x000000000000000000000000000000000001d4edba370e04436a988bad05dada","0x000000000000000000000000000000b52934323a0aec8f803cdaafee2ab7bfb2","0x0000000000000000000000000000000000155312af5e0e25ca9fd61aef9e58ed","0x06270b517855f6f6a608e432883d1d1030a12a1e33022dc142b7728691421da2","0x2af7c794d7b720b25eb1df0afd8c8e3c15b6e518194c3caea7966a5f8210ff04","0x073fe573aeb27d81a5713be93e1365390dcbc3c8e7439ff1d36a84cc014f5642","0x11351b961147431e54535248b58b35cf5cddb9b13827899167617d7a96794d64","0x297c9421c9c3db286770787c35b86bc41583386491b4ae55e5fa81aefa21efc4","0x0f4eeca3ff4a3495f859898937688652d33f9b4dd3e003e12adf15278e0997c3","0x133e3d8b82721d40d919f2326810ba6f07eff3f7d20d86b2bde692a811522019","0x2c502f53c9698b73bb8c8f9b9cf2d705d16a64a7040348b4b39c637a2064316c","0x0cbc1971e1c566cde9d9125c91cdc88e817db182692f836c1a5170a6246eaf73","0x12c47793e7db706c637cd4b4d96d227f569850176b852b1fe8ad522ddb38ef0e","0x0cd7b300e9309a135285be1aeb02b152f97931a7357ab6d609a2cb1970aab877","0x2a7789dfe286c9d0a7592f1c9316e730cb14c9d843aefc4764d76e7f8571c96a","0x248ac54ce3dbf37796621882a4ac76046df5ab680da487fd85cce76b1ae392d3","0x149d1d07cebe320f77b03533e34912545cedeae62bd9778d37724728762b5710","0x00fe29daebdaed61309790e70e2dcefa3f3af4c6c965ce424b8dbcf09b8e4b49","0x2b75b3bace61b731d7f0c003a144b62b0a4fbe9f0d14ca89b0652b70210014b3","0x2588ef27cfb6e0d8c6f9a969b2da44fead30a02ed70a563fd15aa45bb671de1c","0x2b74d7674b55642697b4a1e226eddb0e4918b2d57aa5b99093dc46cadcdea000","0x244c626845d3a5040f08f01e9611f968ad675ca857789149b13a0cfa83a2e064","0x2cb8d02f90cae33fd7bcfb80af4aff067c4f5fc4b3f9228d5b8f768bc8f6c971","0x1372f3d1f04e0c39a50e823d5da03d70bebe19a1b8e28f8c2ff601cc0bfc0095","0x19af6601d2613426a50b7c35d60562a5f2f2634e6af56dac13459632e15570ee","0x13c2a16ed3b65dcd9414659be79af17995d344de34eaf962343b0f1e76c73a57","0x0dd5dcdbd50b8774831d4f01f930804d38b4266dfee085185530880a0c3903c0","0x07e91848d660b11b722638680ac60f20db9507fdc8d610ce762600f5a1aacd29","0x1f9c2a94d10c0a7fb60292cfc46fd3d2501181bea0ffe1f5f2501d474be3a785","0x14edb9c5bd389eae08a5ea2a7a1662894e1e878c142084d966a625bef68cf7c3","0x00000000000000000000000000000000cecd01810814d175f0a533f0067618c4","0x00000000000000000000000000000000f82935013ce5c82720c63e533af41db8","0x000000000000000000000000000000012185688171b6bed850e748b66f7222ac","0x2dd7f5ff2150155c2ac86ebe28d9ecbca2eea812b0021ab2bceae111cfea8325","0x04ea6c2daf2b9e827d2213c3d03953410dcf1ed67ba34a3c00e772be92606a8b","0x163f2bd18dcde52f99b9867c944780fd718d1612927053b139b280fc55013d1b","0x05e388fd160ccac30a8f7b18a4bd042f705e92b5937e8c0e9478e2ff623907c6","0x00ba3f6f527d6ed3ff17a63b1d5be3c42bdfae88fdf63311fc7b871157939309","0x16187d9daa8c2e5a1a9ab15be7ca6a8feebfb31bea76f9a3ca69381881c70561","0x0f64522e4904edb7377b14a7b9dad848829167324ef5c016346b3ad8251191ee","0x273bbe6000a4001dce369e5a36cc0b0ca3fd351665b688238aa8c556a6ca6b8e","0x022d2232efb2faa8307846c9a4c697aabad1b7f1336b35ad72fa8922975b49d9","0x0d82d478bff3955c4b0a34ef94427ca5f9da23147ad953c89f2e428277ec2825","0x18d886be90343010659c231583be61a138e28e37c24771e3cb61fbe2587d0671","0x000000000000000000000000000000196ba6a58dbeb7c34cb1d6287e23d434de","0x00000000000000000000000000000000001df8ae8a1589590f8863c1fefd8dfd","0x000000000000000000000000000000f30e11b2c5fbefa166cbb9f58c5f8e1a4c","0x000000000000000000000000000000000026420ade7666bc0ab1cf1fd9d0c534","0x0000000000000000000000000000000feb5b7d8260d25a1ee1ce76ff461673fc","0x00000000000000000000000000000000002bd2ac6223a80671b777bf5dca70a4","0x000000000000000000000000000000690f757006d2fa1ddb0114c9f268783537","0x000000000000000000000000000000000023ad36feadd91e50118f32e97a0204"] \ No newline at end of file diff --git a/noir/test_programs/execution_success/double_verify_proof/src/main.nr b/noir/test_programs/execution_success/double_verify_proof/src/main.nr index 98cd534266a..fe09923cbe4 100644 --- a/noir/test_programs/execution_success/double_verify_proof/src/main.nr +++ b/noir/test_programs/execution_success/double_verify_proof/src/main.nr @@ -2,31 +2,34 @@ use dep::std; fn main( verification_key: [Field; 114], - proof: [Field; 94], + // This is the proof without public inputs attached. + // + // This means: the size of this does not change with the number of public inputs. + proof: [Field; 93], public_inputs: [Field; 1], + // This is currently not public. It is fine given that the vk is a part of the circuit definition. + // I believe we want to eventually make it public too though. key_hash: Field, - input_aggregation_object: [Field; 16], - proof_b: [Field; 94] -) -> pub [Field; 16] { - let output_aggregation_object_a = std::verify_proof( + proof_b: [Field; 93] +) { + // Create dummy aggregation object + // It is no longer needed but we don't want to make a breaking change to the serialization format + // just yet. We will it in to be anything as the backend is no longer checking it anyways + let unused_input_aggregation_object = [verification_key[0]]; + + let _ = std::verify_proof( verification_key.as_slice(), proof.as_slice(), public_inputs.as_slice(), key_hash, - input_aggregation_object + unused_input_aggregation_object ); - let output_aggregation_object = std::verify_proof( + let _ = std::verify_proof( verification_key.as_slice(), proof_b.as_slice(), public_inputs.as_slice(), key_hash, - output_aggregation_object_a + unused_input_aggregation_object ); - - let mut output = [0; 16]; - for i in 0..16 { - output[i] = output_aggregation_object[i]; - } - output } From 7a4e9be2c2134930fcc2190bceed8a365738f210 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 20:20:26 +0000 Subject: [PATCH 07/19] update double_verify_proof --- .../double_verify_proof/target/acir.gz | Bin 1329 -> 1186 bytes .../double_verify_proof/target/witness.gz | Bin 8346 -> 8144 bytes 2 files changed, 0 insertions(+), 0 deletions(-) diff --git a/noir/test_programs/acir_artifacts/double_verify_proof/target/acir.gz b/noir/test_programs/acir_artifacts/double_verify_proof/target/acir.gz index a2faad65143159827cd22610c42231a0e2b0f9e6..31ff852f775fd90f01e16b25100e391e964dd19d 100644 GIT binary patch delta 1094 zcma*j{WF^f0KoBZTpG$<6EY>M_qTe&rRW~@)<(QUgqzh%o`&?I5u>-nOU6YbbkQ(d zHZSoKLt=vVhC_19EjJCF5{yQk+`8&;=A}#zalKZ{cH1x8Z~Ol6{R2LOR-GuJbIlpV z-<|#e^EgsAPP~7-0zFgM8Htl zvVNWZBPYg9gmaCEJw2Z+ISHCODD#>8nb5QGF(qpf0*rp9cuo8OoM(bGi33I_Q;depfp3^n zHB^o<)Rd^9yo5_lnVKZ0op(=3&I`yRS3zjH^J44~K|t?V@ILYtKpl(hqYyzRW1*W? z#%O;}AS5&3G*gOz$}oOlq6#R#!P##lmyN|o;Q~hep_#u;<%tr1#CaEcYB)6s>qE^+ zLh12D;G2+ME7;whiH1$=c$HV zC?hY2+NV^jC9r`HG4$$d2QS}WD}1{c?-3byp?AGB#_eQtosILCV39Rhj}&Wh`EoE3 z=OsZStFtCu*UsdZgAuq35?iD=YeKR5n0piS$6+N_$jYob$2H+Ovh{um7X%$~XC;>6 zyY3GwRzR);Xoa(on2F2X$IV<$L>*h0JIti5>aYs$JyBaPril66XR?ZY&w-<*s!*2) zy_QI_s~EO6p#gP?;5A8VMqn6PN)gI`&{IWf97m^Via1##DjYL<~jIgRG zO;VkfwLEm2rUoDwpfuX+?y@vPbRn$|NQEy_q|zB8t8FNOrUa5j^QHMNewLl!~uB$aXX0BULHGLU1QM)?MrGo&@-qvbL6s0}4 zTFwo_R+a=cib?>`4u`U}n5vi<|8T{Hdlt07nb{)tz2A~LRxq4WV$wP)EZ=*V)F#Ii v5)&s;C6}I)S_2|$UH+FU!Ly6hP>%i&>c369*&iFL+udhg1X*XI5r{tl^0NpU delta 1247 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 From 7acd6111ad6af9f46c0079d0df51081e47f48f01 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 22:04:28 +0000 Subject: [PATCH 08/19] fix: set input_aggregation for next iteration --- .../cpp/src/barretenberg/dsl/acir_format/acir_format.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp index aa97d901267..642f82cefbf 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp @@ -126,11 +126,11 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b current_input_aggregation_object, constraint.nested_aggregation_object, has_valid_witness_assignments); + current_input_aggregation_object = current_output_aggregation_object; } // Now that the circuit has been completely built, we add the output aggregation as public - // inputs and we ensure that they are first in the public inputs vector, so that we can truncate - // them off of the proof by trimming the first 16 * 32 bytes of the proof. + // inputs. if (!constraint_system.recursion_constraints.empty()) { // First add the output aggregation object as public inputs From a85ba41c2ced4cad52ca9e098b94b266ac4cff23 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Sun, 3 Dec 2023 22:05:51 +0000 Subject: [PATCH 09/19] fix: remove public inputs from proof --- .../dsl/acir_format/recursion_constraint.test.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index 550bd180cc3..90f265af552 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -146,7 +146,11 @@ Builder create_outer_circuit(std::vector& inner_circuits) transcript::HashType::PedersenBlake3s, 16); - const std::vector proof_witnesses = export_transcript_in_recursion_format(transcript); + std::vector proof_witnesses = export_transcript_in_recursion_format(transcript); + // Truncate the public inputs because the ACIR API expects proofs without public inputs + proof_witnesses.erase(proof_witnesses.begin(), + proof_witnesses.begin() + static_cast(num_inner_public_inputs)); + const std::vector key_witnesses = export_key_in_recursion_format(inner_verifier.key); const uint32_t key_hash_start_idx = static_cast(witness_offset); From c11d81207e71dcac0cbbb924713881a5be55a19e Mon Sep 17 00:00:00 2001 From: kevaundray Date: Mon, 4 Dec 2023 00:19:51 +0000 Subject: [PATCH 10/19] set the public input values for the inner circuit in tests --- .../dsl/acir_format/recursion_constraint.test.cpp | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index 90f265af552..85a765a437a 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -147,7 +147,11 @@ Builder create_outer_circuit(std::vector& inner_circuits) 16); std::vector proof_witnesses = export_transcript_in_recursion_format(transcript); - // Truncate the public inputs because the ACIR API expects proofs without public inputs + // - Save the public inputs so that we can set their values. + // - Then truncate them from the proof because the ACIR API expects proofs without public inputs + + std::vector inner_public_input_values( + proof_witnesses.begin(), proof_witnesses.begin() + static_cast(num_inner_public_inputs)); proof_witnesses.erase(proof_witnesses.begin(), proof_witnesses.begin() + static_cast(num_inner_public_inputs)); @@ -206,6 +210,12 @@ Builder create_outer_circuit(std::vector& inner_circuits) for (const auto& wit : key_witnesses) { witness.emplace_back(wit); } + // Set the values for the inner public inputs + // Note: this is confusing, but we minus one here due to the fact that the + // witness values have not taken into account that zero is taken up by the zero_idx + for (size_t i = 0; i < num_inner_public_inputs; ++i) { + witness[inner_public_inputs[i] - 1] = inner_public_input_values[i]; + } witness_offset = key_indices_start_idx + key_witnesses.size(); circuit_idx++; } From c5893316ec14ce626c21a3e6f03fedf46ee936e0 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Mon, 4 Dec 2023 00:27:11 +0000 Subject: [PATCH 11/19] fix: remove output aggregation being set as public input twice --- .../dsl/acir_format/recursion_constraint.test.cpp | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index 85a765a437a..b80d437e6d5 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -220,10 +220,8 @@ Builder create_outer_circuit(std::vector& inner_circuits) circuit_idx++; } - std::vector public_inputs(output_aggregation_object.begin(), output_aggregation_object.end()); - acir_format constraint_system{ .varnum = static_cast(witness.size() + 1), - .public_inputs = public_inputs, + .public_inputs = {}, .logic_constraints = {}, .range_constraints = {}, .sha256_constraints = {}, From ebcdc293f1e994be8ce6290fc9ed76007272dda6 Mon Sep 17 00:00:00 2001 From: kevaundray Date: Mon, 18 Dec 2023 20:30:20 +0000 Subject: [PATCH 12/19] Update noir/test_programs/execution_success/double_verify_proof/src/main.nr Co-authored-by: Maxim Vezenov --- .../execution_success/double_verify_proof/src/main.nr | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/noir/test_programs/execution_success/double_verify_proof/src/main.nr b/noir/test_programs/execution_success/double_verify_proof/src/main.nr index fe09923cbe4..fc30f1c1088 100644 --- a/noir/test_programs/execution_success/double_verify_proof/src/main.nr +++ b/noir/test_programs/execution_success/double_verify_proof/src/main.nr @@ -14,7 +14,7 @@ fn main( ) { // Create dummy aggregation object // It is no longer needed but we don't want to make a breaking change to the serialization format - // just yet. We will it in to be anything as the backend is no longer checking it anyways + // just yet. The object can be anything as the backend is no longer checking it anyways. let unused_input_aggregation_object = [verification_key[0]]; let _ = std::verify_proof( From a8cf7351f47a61336bd33b10941a3711feb82ead Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 19:56:29 +0000 Subject: [PATCH 13/19] move nested_aggregation_object to be a part of the proof --- .../dsl/acir_format/acir_format.cpp | 73 ++++++++++++++---- .../dsl/acir_format/recursion_constraint.cpp | 42 +++++----- .../dsl/acir_format/recursion_constraint.hpp | 12 +-- .../acir_format/recursion_constraint.test.cpp | 76 +++++++++++++++++-- .../stdlib/recursion/verifier/verifier.hpp | 1 + 5 files changed, 158 insertions(+), 46 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp index 6f66e74ce9f..e90a2791853 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp @@ -3,6 +3,7 @@ #include "barretenberg/dsl/acir_format/pedersen.hpp" #include "barretenberg/dsl/acir_format/recursion_constraint.hpp" #include "barretenberg/proof_system/circuit_builder/ultra_circuit_builder.hpp" +#include namespace acir_format { @@ -158,10 +159,10 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b // These are set and modified whenever we encounter a recursion opcode // // These should not be set by the caller - // TODO: Check if this is always the case. ie I won't receive a proof that will set the first - // TODO input_aggregation_object to be non-zero. - // TODO: if not, we can add input_aggregation_object to the proof too for all recursive proofs - // TODO: This might be the case for proof trees where the proofs are created on different machines + // TODO(maxim): Check if this is always the case. ie I won't receive a proof that will set the first + // TODO(maxim): input_aggregation_object to be non-zero. + // TODO(maxim): if not, we can add input_aggregation_object to the proof too for all recursive proofs + // TODO(maxim): This might be the case for proof trees where the proofs are created on different machines std::array current_input_aggregation_object = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; @@ -169,13 +170,45 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + // Get the size of proof with no public inputs prepended to it + // This is used while processing recursion constraints to determine whether + // the proof we are verifying contains a recursive proof itself + auto proof_size_no_pub_inputs = transcript_in_recursion_format_size(); + // Add recursion constraints - for (size_t i = 0; i < constraint_system.recursion_constraints.size(); ++i) { - auto& constraint = constraint_system.recursion_constraints[i]; + for (auto constraint : constraint_system.recursion_constraints) { + // A proof passed into the constraint should be stripped of its public inputs, except in the case where a + // proof contains an aggregation object itself. We refer to this as the `nested_aggregation_object`. The + // verifier circuit requires that the indices to a nested proof aggregation state are a circuit constant. + // The user tells us they how they want these constants set by keeping the nested aggregation object + // attached to the proof as public inputs. As this is the only object that can prepended to the proof if the + // proof is above the expected size (with public inputs stripped) + std::array nested_aggregation_object = {}; + // If the proof has public inputs attached to it, we should handle setting the nested aggregation object + if (constraint.proof.size() > proof_size_no_pub_inputs) { + // The public inputs attached to a proof should match the aggregation object in size + ASSERT(constraint.proof.size() - proof_size_no_pub_inputs == + RecursionConstraint::AGGREGATION_OBJECT_SIZE); + for (size_t i = 0; i < RecursionConstraint::AGGREGATION_OBJECT_SIZE; ++i) { + // Set the nested aggregation object indices to the current size of the public inputs + // This way we know that the nested aggregation object indices will always be the last + // indices of the public inputs + nested_aggregation_object[i] = static_cast(constraint.public_inputs.size()); + // Attach the nested aggregation object to the end of the public inputs to fill in + // the slot where the nested aggregation object index will point into + constraint.public_inputs.emplace_back(constraint.proof[i]); + } + // Remove the aggregation object so that they can be handled as normal public inputs + // in they way taht the recursion constraint expects + constraint.proof.erase(constraint.proof.begin(), + constraint.proof.begin() + + static_cast(RecursionConstraint::AGGREGATION_OBJECT_SIZE)); + } + current_output_aggregation_object = create_recursion_constraints(builder, constraint, current_input_aggregation_object, - constraint.nested_aggregation_object, + nested_aggregation_object, has_valid_witness_assignments); current_input_aggregation_object = current_output_aggregation_object; } @@ -196,6 +229,13 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b std::vector proof_output_witness_indices(current_output_aggregation_object.begin(), current_output_aggregation_object.end()); builder.set_recursive_proof(proof_output_witness_indices); + // for (size_t i = 0; i < proof_output_witness_indices.size(); ++i) { + // info("builder.recursive_proof_public_input_indices[", + // i, + // "] = ", + // builder.recursive_proof_public_input_indices[i]); + // } + // info("builder.public_inputs.size() = ", builder.get_public_inputs().size()); } } } @@ -241,25 +281,26 @@ void create_circuit_with_witness(Builder& builder, acir_format const& constraint /** * @brief Apply an offset to the indices stored in the wires - * @details This method is needed due to the following: Noir constructs "wires" as indices into a "witness" vector. This - * is analogous to the wires and variables vectors in bberg builders. Were it not for the addition of constant variables - * in the constructors of a builder (e.g. zero), we would simply have noir.wires = builder.wires and noir.witness = - * builder.variables. To account for k-many constant variables in the first entries of the variables array, we have - * something like variables = variables.append(noir.witness). Accordingly, the indices in noir.wires have to be - * incremented to account for the offset at which noir.wires was placed into variables. + * @details This method is needed due to the following: Noir constructs "wires" as indices into a "witness" vector. + * This is analogous to the wires and variables vectors in bberg builders. Were it not for the addition of constant + * variables in the constructors of a builder (e.g. zero), we would simply have noir.wires = builder.wires and + * noir.witness = builder.variables. To account for k-many constant variables in the first entries of the variables + * array, we have something like variables = variables.append(noir.witness). Accordingly, the indices in noir.wires + * have to be incremented to account for the offset at which noir.wires was placed into variables. * * @tparam Builder * @param builder */ template void apply_wire_index_offset(Builder& builder) { - // For now, noir has a hard coded witness index offset = 1. Once this is removed, this pre-applied offset goes away + // For now, noir has a hard coded witness index offset = 1. Once this is removed, this pre-applied offset goes + // away const uint32_t pre_applied_noir_offset = 1; auto offset = static_cast(builder.num_vars_added_in_constructor - pre_applied_noir_offset); info("Applying offset = ", offset); - // Apply the offset to the indices stored the wires that were generated from acir. (Do not apply the offset to those - // values that were added in the builder constructor). + // Apply the offset to the indices stored the wires that were generated from acir. (Do not apply the offset to + // those values that were added in the builder constructor). size_t start_index = builder.num_vars_added_in_constructor; for (auto& wire : builder.wires) { for (size_t idx = start_index; idx < wire.size(); ++idx) { diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp index f01d4f60f66..aa31c48d0d4 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp @@ -33,11 +33,6 @@ std::array create_recurs Builder& builder, const RecursionConstraint& input, std::array input_aggregation_object, - // TODO: does this need to be a part of the recursion opcode? - // TODO: or can we figure it out from the vk? - // TODO: either way we could probably have the user explicitly provide it - // TODO: in Noir. - // Note: this is not being used in Noir at the moment std::array nested_aggregation_object, bool has_valid_witness_assignments) { @@ -125,11 +120,9 @@ std::array create_recurs } std::vector proof_fields; - // Prepend the public inputs to the proof fields because this is how the - // core barretenberg library processes proofs (with the public inputs first and not separated) - proof_fields.reserve(input.proof.size() + input.public_inputs.size()); for (const auto& idx : input.public_inputs) { auto field = field_ct::from_witness_index(&builder, idx); + // info("public_input_field = ", field); proof_fields.emplace_back(field); } for (const auto& idx : input.proof) { @@ -141,6 +134,8 @@ std::array create_recurs std::shared_ptr vkey = verification_key_ct::from_field_elements( &builder, key_fields, inner_proof_contains_recursive_proof, nested_aggregation_indices); vkey->program_width = noir_recursive_settings::program_width; + info("input.public_inputs.size() = ", input.public_inputs.size()); + Transcript_ct transcript(&builder, manifest, proof_fields, input.public_inputs.size()); aggregation_state_ct result = proof_system::plonk::stdlib::recursion::verify_proof_( &builder, vkey, transcript, previous_aggregation); @@ -233,6 +228,7 @@ std::vector export_dummy_key_in_recursion_format(const Polynom output.emplace_back(1); // circuit size output.emplace_back(1); // num public inputs + // bool contains = true; output.emplace_back(contains_recursive_proof); // contains_recursive_proof for (size_t i = 0; i < RecursionConstraint::AGGREGATION_OBJECT_SIZE; ++i) { output.emplace_back(0); // recursive_proof_public_input_indices @@ -286,6 +282,7 @@ std::vector export_transcript_in_recursion_format(const transc } else { ASSERT(manifest_element.name == "public_inputs"); const auto public_inputs_vector = transcript.get_field_element_vector(manifest_element.name); + info("public_inputs_vector = ", public_inputs_vector.size()); for (const auto& ele : public_inputs_vector) { fields.emplace_back(ele); } @@ -335,16 +332,20 @@ std::vector export_dummy_transcript_in_recursion_format(const // is composed of two valid G1 points on the curve. Without this conditional we will get a // runtime error that we are attempting to invert 0. if (contains_recursive_proof) { - ASSERT(num_public_inputs == RecursionConstraint::AGGREGATION_OBJECT_SIZE); - for (size_t k = 0; k < RecursionConstraint::NUM_AGGREGATION_ELEMENTS; ++k) { - auto scalar = barretenberg::fr::random_element(); - const auto group_element = barretenberg::g1::affine_element(barretenberg::g1::one * scalar); - auto g1_as_fields = export_g1_affine_element_as_fields(group_element); - fields.emplace_back(g1_as_fields.x_lo); - fields.emplace_back(g1_as_fields.x_hi); - fields.emplace_back(g1_as_fields.y_lo); - fields.emplace_back(g1_as_fields.y_hi); + // ASSERT(num_public_inputs == RecursionConstraint::AGGREGATION_OBJECT_SIZE); + for (size_t j = 0; j < num_public_inputs; ++j) { + // auto scalar = barretenberg::fr::random_element(); + fields.emplace_back(0); } + // for (size_t k = 0; k < RecursionConstraint::NUM_AGGREGATION_ELEMENTS; ++k) { + // auto scalar = barretenberg::fr::random_element(); + // const auto group_element = barretenberg::g1::affine_element(barretenberg::g1::one * + // scalar); auto g1_as_fields = export_g1_affine_element_as_fields(group_element); + // fields.emplace_back(g1_as_fields.x_lo); + // fields.emplace_back(g1_as_fields.x_hi); + // fields.emplace_back(g1_as_fields.y_lo); + // fields.emplace_back(g1_as_fields.y_hi); + // } } else { for (size_t j = 0; j < num_public_inputs; ++j) { // auto scalar = barretenberg::fr::random_element(); @@ -358,6 +359,13 @@ std::vector export_dummy_transcript_in_recursion_format(const return fields; } +size_t transcript_in_recursion_format_size() +{ + const auto manifest = Composer::create_manifest(0); + auto dummy_transcript = export_dummy_transcript_in_recursion_format(manifest, false); + return dummy_transcript.size(); +} + G1AsFields export_g1_affine_element_as_fields(const barretenberg::g1::affine_element& group_element) { const uint256_t x = group_element.x; diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp index 345b6744cd6..0bc53e5834a 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp @@ -53,13 +53,14 @@ struct RecursionConstraint { std::vector proof; std::vector public_inputs; uint32_t key_hash; - // TODO:This is now unused, but we keep it here for backwards compatibility + // TODO(maxim):This is now unused, but we keep it here for backwards compatibility std::array input_aggregation_object; - // TODO: This is now unused, but we keep it here for backwards compatibility + // TODO(maxim): This is now unused, but we keep it here for backwards compatibility std::array output_aggregation_object; - // TODO: This is currently not being used on the Noir level at all - // TODO: we don't have a way to specify that the proof we are creating contains a - // TODO: aggregation object (ie it is also verifying a proof) + // TODO(maxim): This is currently not being used on the Noir level at all, + // TODO(maxim): but we keep it here for backwards compatibility + // TODO(maxim): The object is now currently contained by the `proof` field + // TODO(maxim): and is handled when serializing ACIR to a barretenberg circuit std::array nested_aggregation_object; friend bool operator==(RecursionConstraint const& lhs, RecursionConstraint const& rhs) = default; @@ -79,6 +80,7 @@ std::vector export_dummy_key_in_recursion_format(const Polynom std::vector export_transcript_in_recursion_format(const transcript::StandardTranscript& transcript); std::vector export_dummy_transcript_in_recursion_format(const transcript::Manifest& manifest, const bool contains_recursive_proof); +size_t transcript_in_recursion_format_size(); // In order to interact with a recursive aggregation state inside of a circuit, we need to represent its internal G1 // elements as field elements. This happens in multiple locations when creating a recursion constraint. The struct and diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index b80d437e6d5..66306313093 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -131,16 +131,21 @@ Builder create_outer_circuit(std::vector& inner_circuits) size_t circuit_idx = 0; for (auto& inner_circuit : inner_circuits) { + info("NEW inner_circuit"); const bool has_input_aggregation_object = circuit_idx > 0; auto inner_composer = Composer(); auto inner_prover = inner_composer.create_prover(inner_circuit); auto inner_proof = inner_prover.construct_proof(); + auto proof_data = inner_proof.proof_data; + info("inner_proof.size() = ", proof_data.size()); auto inner_verifier = inner_composer.create_verifier(inner_circuit); const bool has_nested_proof = inner_verifier.key->contains_recursive_proof; - const size_t num_inner_public_inputs = inner_circuit.get_public_inputs().size(); + info("has_nested_proof = ", has_nested_proof); + const size_t num_inner_public_inputs = inner_circuit.get_public_inputs().size(); + // info("num_inner_public_inputs = ", num_inner_public_inputs); transcript::StandardTranscript transcript(inner_proof.proof_data, Composer::create_manifest(num_inner_public_inputs), transcript::HashType::PedersenBlake3s, @@ -149,11 +154,17 @@ Builder create_outer_circuit(std::vector& inner_circuits) std::vector proof_witnesses = export_transcript_in_recursion_format(transcript); // - Save the public inputs so that we can set their values. // - Then truncate them from the proof because the ACIR API expects proofs without public inputs - + info("proof_witnesses.size() = ", proof_witnesses.size()); std::vector inner_public_input_values( proof_witnesses.begin(), proof_witnesses.begin() + static_cast(num_inner_public_inputs)); - proof_witnesses.erase(proof_witnesses.begin(), - proof_witnesses.begin() + static_cast(num_inner_public_inputs)); + + // We want to make sure that we do not remove the nested aggregation object in the case of the proof we want to + // recursively verify contains a recursive proof itself. We are safe to remove the inner public inputs as for + // this test + if (!has_nested_proof) { + proof_witnesses.erase(proof_witnesses.begin(), + proof_witnesses.begin() + static_cast(num_inner_public_inputs)); + } const std::vector key_witnesses = export_key_in_recursion_format(inner_verifier.key); @@ -178,19 +189,43 @@ Builder create_outer_circuit(std::vector& inner_circuits) if (has_nested_proof) { for (size_t i = 0; i < 16; ++i) { nested_aggregation_object[i] = inner_circuit.recursive_proof_public_input_indices[i]; + // info("inner_circuit.recursive_proof_public_input_indices[i] = ", + // inner_circuit.recursive_proof_public_input_indices[i]); } } + info("proof_witnesses.size() = ", proof_witnesses.size()); for (size_t i = 0; i < proof_witnesses.size(); ++i) { proof_indices.emplace_back(static_cast(i + proof_indices_start_idx)); } + info("about to update proof indices"); + // NOTE: As the agg object is represented as proof indices, we actually want to fetch the public input indices + // TODO(maxim): could I instead simply keep the aggregation object attached. + // then I automatically add it into the public input myself based upon the witness in the key?? + // but I need the indices to be a circuit constant so I cannot just do that. + // I could always attach them to the beginning of the public inputs? + // if (has_nested_proof) { + // for (size_t i = 0; i < 16; ++i) { + // proof_indices[i] = inner_circuit.recursive_proof_public_input_indices[i]; + // info("proof_indices[", i, "] = ", proof_indices[i]); + // } + // } + const size_t key_size = key_witnesses.size(); for (size_t i = 0; i < key_size; ++i) { key_indices.emplace_back(static_cast(i + key_indices_start_idx)); } + if (!has_nested_proof) { + for (size_t i = 0; i < num_inner_public_inputs; ++i) { + inner_public_inputs.push_back(static_cast(i + public_input_start_idx)); + } + } for (size_t i = 0; i < num_inner_public_inputs; ++i) { - inner_public_inputs.push_back(static_cast(i + public_input_start_idx)); + info("inner_public_inputs[", i, "] = ", i + public_input_start_idx); } - + for (size_t i = 0; i < inner_public_inputs.size(); ++i) { + info("inner_public_inputs[", i, "] = ", inner_public_inputs[i]); + } + info("inner_public_inputs.size() = ", inner_public_inputs.size()); RecursionConstraint recursion_constraint{ .key = key_indices, .proof = proof_indices, @@ -201,21 +236,41 @@ Builder create_outer_circuit(std::vector& inner_circuits) .nested_aggregation_object = nested_aggregation_object, }; recursion_constraints.push_back(recursion_constraint); + info("proof_indices_start_idx - witness_offset = ", proof_indices_start_idx - witness_offset); + info("proof_witnesses.len() = ", proof_witnesses.size()); for (size_t i = 0; i < proof_indices_start_idx - witness_offset; ++i) { witness.emplace_back(0); } for (const auto& wit : proof_witnesses) { witness.emplace_back(wit); } + for (const auto& wit : key_witnesses) { witness.emplace_back(wit); } + + // for (size_t i = 0; i < num_inner_public_inputs + 1; ++i) { + // info("witness[", i, "] = ", witness[i]); + // } + info("num_inner_public_inputs = ", num_inner_public_inputs); + // Set the values for the inner public inputs // Note: this is confusing, but we minus one here due to the fact that the // witness values have not taken into account that zero is taken up by the zero_idx - for (size_t i = 0; i < num_inner_public_inputs; ++i) { - witness[inner_public_inputs[i] - 1] = inner_public_input_values[i]; + if (!has_nested_proof) { + for (size_t i = 0; i < num_inner_public_inputs; ++i) { + info("i = ", i); + info("inner_public_inputs[i] = ", inner_public_inputs[i]); + info("inner_public_input_values[i] = ", inner_public_input_values[i]); + witness[inner_public_inputs[i] - 1] = inner_public_input_values[i]; + } } + // for (size_t i = 0; i < num_inner_public_inputs; ++i) { + // info("i = ", i); + // info("inner_public_inputs[i] = ", inner_public_inputs[i]); + // info("inner_public_input_values[i] = ", inner_public_input_values[i]); + // witness[inner_public_inputs[i] - 1] = inner_public_input_values[i]; + // } witness_offset = key_indices_start_idx + key_witnesses.size(); circuit_idx++; } @@ -316,6 +371,8 @@ TEST_F(AcirRecursionConstraint, TestOneOuterRecursiveCircuit) auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); + auto proof_data = proof.proof_data; + info("proof_data.size() = ", proof_data.size()); auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); } @@ -340,11 +397,14 @@ TEST_F(AcirRecursionConstraint, TestFullRecursiveComposition) auto layer_3_circuit = create_outer_circuit(layer_2_circuits); info("created third outer circuit"); info("number of gates in layer 3 circuit = ", layer_3_circuit.get_num_gates()); + info("layer_3_circuit.public_inputs().size() = ", layer_3_circuit.get_public_inputs().size()); auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); + auto proof_data = proof.proof_data; + info("proof_data.size() = ", proof_data.size()); auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); } diff --git a/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp b/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp index 0084585dbdc..c3def351d4e 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp +++ b/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp @@ -343,6 +343,7 @@ aggregation_state verify_proof_(typename Curve::Builder* context, const fr_ct l1 = public_inputs[idx1]; const fr_ct l2 = public_inputs[idx2]; const fr_ct l3 = public_inputs[idx3]; + l0.create_range_constraint(fq_ct::NUM_LIMB_BITS, "l0"); l1.create_range_constraint(fq_ct::NUM_LIMB_BITS, "l1"); l2.create_range_constraint(fq_ct::NUM_LIMB_BITS, "l2"); From 6a05231038f85391c891c4898b5c211d2421e152 Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 20:02:10 +0000 Subject: [PATCH 14/19] cleanup test prints --- .../acir_format/recursion_constraint.test.cpp | 61 ++++--------------- 1 file changed, 12 insertions(+), 49 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index 66306313093..fab7322ef1a 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -131,21 +131,16 @@ Builder create_outer_circuit(std::vector& inner_circuits) size_t circuit_idx = 0; for (auto& inner_circuit : inner_circuits) { - info("NEW inner_circuit"); const bool has_input_aggregation_object = circuit_idx > 0; auto inner_composer = Composer(); auto inner_prover = inner_composer.create_prover(inner_circuit); auto inner_proof = inner_prover.construct_proof(); - auto proof_data = inner_proof.proof_data; - info("inner_proof.size() = ", proof_data.size()); auto inner_verifier = inner_composer.create_verifier(inner_circuit); const bool has_nested_proof = inner_verifier.key->contains_recursive_proof; - info("has_nested_proof = ", has_nested_proof); const size_t num_inner_public_inputs = inner_circuit.get_public_inputs().size(); - // info("num_inner_public_inputs = ", num_inner_public_inputs); transcript::StandardTranscript transcript(inner_proof.proof_data, Composer::create_manifest(num_inner_public_inputs), transcript::HashType::PedersenBlake3s, @@ -154,13 +149,12 @@ Builder create_outer_circuit(std::vector& inner_circuits) std::vector proof_witnesses = export_transcript_in_recursion_format(transcript); // - Save the public inputs so that we can set their values. // - Then truncate them from the proof because the ACIR API expects proofs without public inputs - info("proof_witnesses.size() = ", proof_witnesses.size()); std::vector inner_public_input_values( proof_witnesses.begin(), proof_witnesses.begin() + static_cast(num_inner_public_inputs)); // We want to make sure that we do not remove the nested aggregation object in the case of the proof we want to - // recursively verify contains a recursive proof itself. We are safe to remove the inner public inputs as for - // this test + // recursively verify contains a recursive proof itself. We are safe to keep all the inner public inputs + // as in these tests the outer circuits do not have public inputs themselves if (!has_nested_proof) { proof_witnesses.erase(proof_witnesses.begin(), proof_witnesses.begin() + static_cast(num_inner_public_inputs)); @@ -189,43 +183,23 @@ Builder create_outer_circuit(std::vector& inner_circuits) if (has_nested_proof) { for (size_t i = 0; i < 16; ++i) { nested_aggregation_object[i] = inner_circuit.recursive_proof_public_input_indices[i]; - // info("inner_circuit.recursive_proof_public_input_indices[i] = ", - // inner_circuit.recursive_proof_public_input_indices[i]); } } - info("proof_witnesses.size() = ", proof_witnesses.size()); for (size_t i = 0; i < proof_witnesses.size(); ++i) { proof_indices.emplace_back(static_cast(i + proof_indices_start_idx)); } - info("about to update proof indices"); - // NOTE: As the agg object is represented as proof indices, we actually want to fetch the public input indices - // TODO(maxim): could I instead simply keep the aggregation object attached. - // then I automatically add it into the public input myself based upon the witness in the key?? - // but I need the indices to be a circuit constant so I cannot just do that. - // I could always attach them to the beginning of the public inputs? - // if (has_nested_proof) { - // for (size_t i = 0; i < 16; ++i) { - // proof_indices[i] = inner_circuit.recursive_proof_public_input_indices[i]; - // info("proof_indices[", i, "] = ", proof_indices[i]); - // } - // } - - const size_t key_size = key_witnesses.size(); - for (size_t i = 0; i < key_size; ++i) { + for (size_t i = 0; i < key_witnesses.size(); ++i) { key_indices.emplace_back(static_cast(i + key_indices_start_idx)); } + // In the case of a nested proof we keep the nested aggregation object attached to the proof, + // thus we do not explicitly have to keep the public inputs while setting up the initial recursion constraint. + // They will later be attached as public inputs when creating the circuit. if (!has_nested_proof) { for (size_t i = 0; i < num_inner_public_inputs; ++i) { inner_public_inputs.push_back(static_cast(i + public_input_start_idx)); } } - for (size_t i = 0; i < num_inner_public_inputs; ++i) { - info("inner_public_inputs[", i, "] = ", i + public_input_start_idx); - } - for (size_t i = 0; i < inner_public_inputs.size(); ++i) { - info("inner_public_inputs[", i, "] = ", inner_public_inputs[i]); - } - info("inner_public_inputs.size() = ", inner_public_inputs.size()); + RecursionConstraint recursion_constraint{ .key = key_indices, .proof = proof_indices, @@ -236,8 +210,7 @@ Builder create_outer_circuit(std::vector& inner_circuits) .nested_aggregation_object = nested_aggregation_object, }; recursion_constraints.push_back(recursion_constraint); - info("proof_indices_start_idx - witness_offset = ", proof_indices_start_idx - witness_offset); - info("proof_witnesses.len() = ", proof_witnesses.size()); + for (size_t i = 0; i < proof_indices_start_idx - witness_offset; ++i) { witness.emplace_back(0); } @@ -249,28 +222,18 @@ Builder create_outer_circuit(std::vector& inner_circuits) witness.emplace_back(wit); } - // for (size_t i = 0; i < num_inner_public_inputs + 1; ++i) { - // info("witness[", i, "] = ", witness[i]); - // } - info("num_inner_public_inputs = ", num_inner_public_inputs); - // Set the values for the inner public inputs // Note: this is confusing, but we minus one here due to the fact that the // witness values have not taken into account that zero is taken up by the zero_idx + // + // We once again have to check whether we have a nested proof, because if we do have one + // then we could get a segmentation fault as `inner_public_inputs` was never filled with values. if (!has_nested_proof) { for (size_t i = 0; i < num_inner_public_inputs; ++i) { - info("i = ", i); - info("inner_public_inputs[i] = ", inner_public_inputs[i]); - info("inner_public_input_values[i] = ", inner_public_input_values[i]); witness[inner_public_inputs[i] - 1] = inner_public_input_values[i]; } } - // for (size_t i = 0; i < num_inner_public_inputs; ++i) { - // info("i = ", i); - // info("inner_public_inputs[i] = ", inner_public_inputs[i]); - // info("inner_public_input_values[i] = ", inner_public_input_values[i]); - // witness[inner_public_inputs[i] - 1] = inner_public_input_values[i]; - // } + witness_offset = key_indices_start_idx + key_witnesses.size(); circuit_idx++; } From 50b486f5859d23a918fb1dae029b0969646cfbfd Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 20:07:30 +0000 Subject: [PATCH 15/19] more print cleanup --- .../dsl/acir_format/recursion_constraint.test.cpp | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index fab7322ef1a..e32cfa756c7 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -271,11 +271,8 @@ TEST_F(AcirRecursionConstraint, TestBasicDoubleRecursionConstraints) auto layer_2_circuit = create_outer_circuit(layer_1_circuits); - info("circuit gates = ", layer_2_circuit.get_num_gates()); - auto layer_2_composer = Composer(); auto prover = layer_2_composer.create_ultra_with_keccak_prover(layer_2_circuit); - info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); auto verifier = layer_2_composer.create_ultra_with_keccak_verifier(layer_2_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); @@ -328,14 +325,11 @@ TEST_F(AcirRecursionConstraint, TestOneOuterRecursiveCircuit) auto layer_3_circuit = create_outer_circuit(layer_2_circuits); info("created second outer circuit"); - info("number of gates in layer 3 = ", layer_3_circuit.get_num_gates()); auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); - info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); auto proof_data = proof.proof_data; - info("proof_data.size() = ", proof_data.size()); auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); } @@ -359,15 +353,11 @@ TEST_F(AcirRecursionConstraint, TestFullRecursiveComposition) auto layer_3_circuit = create_outer_circuit(layer_2_circuits); info("created third outer circuit"); - info("number of gates in layer 3 circuit = ", layer_3_circuit.get_num_gates()); - info("layer_3_circuit.public_inputs().size() = ", layer_3_circuit.get_public_inputs().size()); auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); - info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); auto proof_data = proof.proof_data; - info("proof_data.size() = ", proof_data.size()); auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); } From b6e469903018225ff114d6116c850fed81fc526f Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 20:15:04 +0000 Subject: [PATCH 16/19] last little cleanup --- .../src/barretenberg/dsl/acir_format/recursion_constraint.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp index 66028cf9a4f..6212d145a2a 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp @@ -283,7 +283,6 @@ std::vector export_transcript_in_recursion_format(const transc } else { ASSERT(manifest_element.name == "public_inputs"); const auto public_inputs_vector = transcript.get_field_element_vector(manifest_element.name); - info("public_inputs_vector = ", public_inputs_vector.size()); for (const auto& ele : public_inputs_vector) { fields.emplace_back(ele); } From 0da144ed93b1b27a2a1efa92ec4aa7e71a96c7fe Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 20:28:52 +0000 Subject: [PATCH 17/19] cleanup and remove old testing code --- .../dsl/acir_format/acir_format.cpp | 7 ------ .../dsl/acir_format/recursion_constraint.cpp | 23 ++++++++----------- .../acir_format/recursion_constraint.test.cpp | 5 ++-- .../stdlib/recursion/verifier/verifier.hpp | 1 - 4 files changed, 11 insertions(+), 25 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp index e90a2791853..f479ff5aa65 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp @@ -229,13 +229,6 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b std::vector proof_output_witness_indices(current_output_aggregation_object.begin(), current_output_aggregation_object.end()); builder.set_recursive_proof(proof_output_witness_indices); - // for (size_t i = 0; i < proof_output_witness_indices.size(); ++i) { - // info("builder.recursive_proof_public_input_indices[", - // i, - // "] = ", - // builder.recursive_proof_public_input_indices[i]); - // } - // info("builder.public_inputs.size() = ", builder.get_public_inputs().size()); } } } diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp index 6212d145a2a..3b39bb04b04 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp @@ -229,7 +229,6 @@ std::vector export_dummy_key_in_recursion_format(const Polynom output.emplace_back(1); // circuit size output.emplace_back(1); // num public inputs - // bool contains = true; output.emplace_back(contains_recursive_proof); // contains_recursive_proof for (size_t i = 0; i < RecursionConstraint::AGGREGATION_OBJECT_SIZE; ++i) { output.emplace_back(0); // recursive_proof_public_input_indices @@ -332,20 +331,16 @@ std::vector export_dummy_transcript_in_recursion_format(const // is composed of two valid G1 points on the curve. Without this conditional we will get a // runtime error that we are attempting to invert 0. if (contains_recursive_proof) { - // ASSERT(num_public_inputs == RecursionConstraint::AGGREGATION_OBJECT_SIZE); - for (size_t j = 0; j < num_public_inputs; ++j) { - // auto scalar = barretenberg::fr::random_element(); - fields.emplace_back(0); + ASSERT(num_public_inputs == RecursionConstraint::AGGREGATION_OBJECT_SIZE); + for (size_t k = 0; k < RecursionConstraint::NUM_AGGREGATION_ELEMENTS; ++k) { + auto scalar = barretenberg::fr::random_element(); + const auto group_element = barretenberg::g1::affine_element(barretenberg::g1::one * scalar); + auto g1_as_fields = export_g1_affine_element_as_fields(group_element); + fields.emplace_back(g1_as_fields.x_lo); + fields.emplace_back(g1_as_fields.x_hi); + fields.emplace_back(g1_as_fields.y_lo); + fields.emplace_back(g1_as_fields.y_hi); } - // for (size_t k = 0; k < RecursionConstraint::NUM_AGGREGATION_ELEMENTS; ++k) { - // auto scalar = barretenberg::fr::random_element(); - // const auto group_element = barretenberg::g1::affine_element(barretenberg::g1::one * - // scalar); auto g1_as_fields = export_g1_affine_element_as_fields(group_element); - // fields.emplace_back(g1_as_fields.x_lo); - // fields.emplace_back(g1_as_fields.x_hi); - // fields.emplace_back(g1_as_fields.y_lo); - // fields.emplace_back(g1_as_fields.y_hi); - // } } else { for (size_t j = 0; j < num_public_inputs; ++j) { // auto scalar = barretenberg::fr::random_element(); diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index e32cfa756c7..7481e7ec48c 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -188,7 +188,8 @@ Builder create_outer_circuit(std::vector& inner_circuits) for (size_t i = 0; i < proof_witnesses.size(); ++i) { proof_indices.emplace_back(static_cast(i + proof_indices_start_idx)); } - for (size_t i = 0; i < key_witnesses.size(); ++i) { + const size_t key_size = key_witnesses.size(); + for (size_t i = 0; i < key_size; ++i) { key_indices.emplace_back(static_cast(i + key_indices_start_idx)); } // In the case of a nested proof we keep the nested aggregation object attached to the proof, @@ -329,7 +330,6 @@ TEST_F(AcirRecursionConstraint, TestOneOuterRecursiveCircuit) auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); auto proof = prover.construct_proof(); - auto proof_data = proof.proof_data; auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); } @@ -357,7 +357,6 @@ TEST_F(AcirRecursionConstraint, TestFullRecursiveComposition) auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); auto proof = prover.construct_proof(); - auto proof_data = proof.proof_data; auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); } diff --git a/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp b/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp index c3def351d4e..0084585dbdc 100644 --- a/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp +++ b/barretenberg/cpp/src/barretenberg/stdlib/recursion/verifier/verifier.hpp @@ -343,7 +343,6 @@ aggregation_state verify_proof_(typename Curve::Builder* context, const fr_ct l1 = public_inputs[idx1]; const fr_ct l2 = public_inputs[idx2]; const fr_ct l3 = public_inputs[idx3]; - l0.create_range_constraint(fq_ct::NUM_LIMB_BITS, "l0"); l1.create_range_constraint(fq_ct::NUM_LIMB_BITS, "l1"); l2.create_range_constraint(fq_ct::NUM_LIMB_BITS, "l2"); From 8b5c39a91d0ac05253e30a432817cbb5211a21a3 Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 20:31:22 +0000 Subject: [PATCH 18/19] bring back prover gate counts: --- .../dsl/acir_format/recursion_constraint.test.cpp | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp index 7481e7ec48c..a64f65462bc 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.test.cpp @@ -272,8 +272,11 @@ TEST_F(AcirRecursionConstraint, TestBasicDoubleRecursionConstraints) auto layer_2_circuit = create_outer_circuit(layer_1_circuits); + info("circuit gates = ", layer_2_circuit.get_num_gates()); + auto layer_2_composer = Composer(); auto prover = layer_2_composer.create_ultra_with_keccak_prover(layer_2_circuit); + info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); auto verifier = layer_2_composer.create_ultra_with_keccak_verifier(layer_2_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); @@ -326,9 +329,11 @@ TEST_F(AcirRecursionConstraint, TestOneOuterRecursiveCircuit) auto layer_3_circuit = create_outer_circuit(layer_2_circuits); info("created second outer circuit"); + info("number of gates in layer 3 = ", layer_3_circuit.get_num_gates()); auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); + info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); @@ -353,9 +358,11 @@ TEST_F(AcirRecursionConstraint, TestFullRecursiveComposition) auto layer_3_circuit = create_outer_circuit(layer_2_circuits); info("created third outer circuit"); + info("number of gates in layer 3 circuit = ", layer_3_circuit.get_num_gates()); auto layer_3_composer = Composer(); auto prover = layer_3_composer.create_ultra_with_keccak_prover(layer_3_circuit); + info("prover gates = ", prover.circuit_size); auto proof = prover.construct_proof(); auto verifier = layer_3_composer.create_ultra_with_keccak_verifier(layer_3_circuit); EXPECT_EQ(verifier.verify_proof(proof), true); From 09dfc2c408575b27dc7d2a6f305cd8e4cd10cf26 Mon Sep 17 00:00:00 2001 From: vezenovm Date: Thu, 21 Dec 2023 23:13:55 +0000 Subject: [PATCH 19/19] rename transcript_in_recursion_format_size to recursion_proof_size_without_public_inputs --- .../cpp/src/barretenberg/dsl/acir_format/acir_format.cpp | 2 +- .../src/barretenberg/dsl/acir_format/recursion_constraint.cpp | 2 +- .../src/barretenberg/dsl/acir_format/recursion_constraint.hpp | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp index f479ff5aa65..b36ba94d33e 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/acir_format.cpp @@ -173,7 +173,7 @@ void build_constraints(Builder& builder, acir_format const& constraint_system, b // Get the size of proof with no public inputs prepended to it // This is used while processing recursion constraints to determine whether // the proof we are verifying contains a recursive proof itself - auto proof_size_no_pub_inputs = transcript_in_recursion_format_size(); + auto proof_size_no_pub_inputs = recursion_proof_size_without_public_inputs(); // Add recursion constraints for (auto constraint : constraint_system.recursion_constraints) { diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp index 3b39bb04b04..813f2022745 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.cpp @@ -354,7 +354,7 @@ std::vector export_dummy_transcript_in_recursion_format(const return fields; } -size_t transcript_in_recursion_format_size() +size_t recursion_proof_size_without_public_inputs() { const auto manifest = Composer::create_manifest(0); auto dummy_transcript = export_dummy_transcript_in_recursion_format(manifest, false); diff --git a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp index 0bc53e5834a..8f6618106d2 100644 --- a/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp +++ b/barretenberg/cpp/src/barretenberg/dsl/acir_format/recursion_constraint.hpp @@ -80,7 +80,7 @@ std::vector export_dummy_key_in_recursion_format(const Polynom std::vector export_transcript_in_recursion_format(const transcript::StandardTranscript& transcript); std::vector export_dummy_transcript_in_recursion_format(const transcript::Manifest& manifest, const bool contains_recursive_proof); -size_t transcript_in_recursion_format_size(); +size_t recursion_proof_size_without_public_inputs(); // In order to interact with a recursive aggregation state inside of a circuit, we need to represent its internal G1 // elements as field elements. This happens in multiple locations when creating a recursion constraint. The struct and