21template <
typename Flavor,
typename IO,
typename Circuit =
typename Flavor::CircuitBuilder>
27 if (!witness.empty()) {
30 return acir_format::create_circuit<Circuit>(program, metadata);
33template <
typename Flavor,
typename IO>
35 std::vector<uint8_t>&& witness)
38 auto initial_time = std::chrono::high_resolution_clock::now();
41 auto final_time = std::chrono::high_resolution_clock::now();
42 auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(final_time - initial_time);
43 info(
"CircuitProve: Proving key computed in ", duration.count(),
" ms");
48 if constexpr (IO::HasIPA) {
49 BB_ASSERT(!prover_instance->ipa_proof.empty(),
50 "RollupIO circuit expected IPA proof but none was provided. "
51 "Ensure the circuit includes IPA accumulation data.");
53 BB_ASSERT(prover_instance->ipa_proof.empty(),
54 "Non-rollup circuit should not have IPA proof. "
55 "Use ipa_accumulation=true in settings for rollup circuits.");
58 return prover_instance;
60template <
typename Flavor,
typename IO>
62 std::vector<uint8_t>&& witness,
63 std::vector<uint8_t>&& vk_bytes)
71 std::shared_ptr<VerificationKey>
vk;
72 if (vk_bytes.empty()) {
73 info(
"WARNING: computing verification key while proving. Pass in a precomputed vk for better performance.");
76 validate_vk_size<VerificationKey>(vk_bytes);
85 size_t num_public_inputs = prover.num_public_inputs();
86 BB_ASSERT_GTE(num_public_inputs, IO::PUBLIC_INPUTS_SIZE,
"Public inputs should contain the expected IO structure.");
87 size_t num_inner_public_inputs = num_public_inputs - IO::PUBLIC_INPUTS_SIZE;
91 if (vk_bytes.empty()) {
96 return { .public_inputs =
98 full_proof.begin() +
static_cast<std::ptrdiff_t>(num_inner_public_inputs) },
104template <
typename Flavor,
typename IO>
105bool _verify(
const std::vector<uint8_t>& vk_bytes,
110 using VKAndHash =
typename Flavor::VKAndHash;
115 if (vk_bytes.size() != expected_vk_size) {
117 "Proof verification failed: invalid VK size. Expected ", expected_vk_size,
" bytes, got ", vk_bytes.size());
123 Verifier verifier{ vk_and_hash };
126 const size_t log_n = verifier.compute_log_n();
128 if (proof.size() != expected_size) {
129 info(
"Proof verification failed: invalid proof size. Expected ", expected_size,
", got ", proof.size());
133 auto complete_proof = concatenate_proof<Flavor>(public_inputs, proof);
134 bool verified = verifier.verify_proof(complete_proof).result;
137 info(
"Proof verified successfully");
139 info(
"Proof verification failed");
157 auto prover_instance = _compute_prover_instance<Flavor, IO>(
std::move(circuit.bytecode), {});
165template <
typename Flavor,
typename IO>
175 response.
num_acir_opcodes =
static_cast<uint32_t
>(constraint_system.num_acir_opcodes);
178 auto builder = acir_format::create_circuit<Circuit>(program, metadata);
181 response.
num_gates =
static_cast<uint32_t
>(
builder.get_finalized_total_circuit_size());
185 std::vector<uint32_t>(program.constraints.gates_per_opcode.begin(), program.constraints.gates_per_opcode.end());
194 return _stats<Flavor, IO>(
std::move(circuit.bytecode), include_gates_per_opcode);
202 return _verify<Flavor, IO>(verification_key, public_inputs, proof);
212 validate_vk_size<VK>(verification_key);
215 auto vk = from_buffer<VK>(verification_key);
216 std::vector<bb::fr> fields;
217 fields =
vk.to_field_elements();
227 validate_vk_size<VK>(verification_key);
230 auto vk = from_buffer<VK>(verification_key);
231 std::vector<bb::fr> fields;
232 fields =
vk.to_field_elements();
241 validate_vk_size<VK>(verification_key);
250 if (settings.optimized_solidity_verifier) {
#define BB_ASSERT(expression,...)
#define BB_ASSERT_GTE(left, right,...)
std::shared_ptr< Napi::ThreadSafeFunction > bytecode
#define BB_BENCH_NAME(name)
Shared type definitions for the Barretenberg RPC API.
UltraHonk-specific command definitions for the Barretenberg RPC API.
ECCVMCircuitBuilder CircuitBuilder
FixedVKAndHash_< PrecomputedEntities< Commitment >, BF, ECCVMHardcodedVKAndHash > VerificationKey
The verification key stores commitments to the precomputed polynomials used by the verifier.
NativeVerificationKey_< PrecomputedEntities< Commitment >, Codec, HashFunction, CommitmentKey > VerificationKey
The verification key stores commitments to the precomputed (non-witness) polynomials used by the veri...
Base Native verification key class.
static constexpr size_t calc_num_data_types()
Calculate the number of field elements needed for serialization.
NativeVerificationKey_< PrecomputedEntities< Commitment >, Codec, HashFunction, CommitmentKey > VerificationKey
The verification key stores commitments to the precomputed (non-witness) polynomials used by the veri...
NativeVerificationKey_< PrecomputedEntities< Commitment >, Codec, HashFunction, CommitmentKey > VerificationKey
std::string get_honk_solidity_verifier(auto const &verification_key)
std::string get_optimized_honk_solidity_verifier(auto const &verification_key)
std::string get_honk_zk_solidity_verifier(auto const &verification_key)
std::string get_optimized_honk_zk_solidity_verifier(auto const &verification_key)
std::shared_ptr< ProverInstance_< Flavor > > _compute_prover_instance(std::vector< uint8_t > &&bytecode, std::vector< uint8_t > &&witness)
bool _verify(const std::vector< uint8_t > &vk_bytes, const std::vector< uint256_t > &public_inputs, const std::vector< uint256_t > &proof)
acir_format::ProgramMetadata _create_program_metadata()
Circuit _compute_circuit(std::vector< uint8_t > &&bytecode, std::vector< uint8_t > &&witness)
CircuitStats::Response _stats(std::vector< uint8_t > &&bytecode, bool include_gates_per_opcode)
std::vector< uint256_t > vk_to_uint256_fields(const VK &vk)
Convert VK to uint256 field elements, handling flavor-specific return types.
CircuitProve::Response _prove(std::vector< uint8_t > &&bytecode, std::vector< uint8_t > &&witness, std::vector< uint8_t > &&vk_bytes)
auto dispatch_by_settings(const ProofSystemSettings &settings, Operation &&operation)
Dispatch to the correct Flavor and IO type based on proof system settings.
field< Bn254FrParams > fr
VerifierCommitmentKey< Curve > vk
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::vector< uint8_t > to_buffer(T const &value)
Full Honk proof layout (used by UltraVerifier).
std::vector< uint8_t > bytes
Response execute(const BBApiRequest &request={}) &&
Contains proof and public inputs. Both are given as vectors of fields. To be used for verification....
Response execute(const BBApiRequest &request={}) &&
uint32_t num_gates_dyadic
std::vector< uint32_t > gates_per_opcode
uint32_t num_acir_opcodes
Response execute(const BBApiRequest &request={}) &&
Response execute(const BBApiRequest &request={}) &&
Response execute(const BBApiRequest &request={}) &&
Response execute(const BBApiRequest &request={}) &&
Response execute(const BBApiRequest &request={}) &&