octez-libs.distributed-plonk
Super_impl.MP
aggregation
bare_functor_outputs
bare_sigs
bare_structs
communication
distribution
octez-libs.aplonk
octez-libs.base
octez-libs.base-test-helpers
octez-libs.bls12-381-hash
octez-libs.bls12-381-polynomial
octez-libs.bls12-381-signature
octez-libs.clic
octez-libs.context
octez-libs.crypto
octez-libs.crypto-dal
octez-libs.epoxy-tx
octez-libs.error-monad
octez-libs.event-logging
octez-libs.event-logging-test-helpers
octez-libs.expect-helper
octez-libs.hacl
octez-libs.kzg
octez-libs.lazy-containers
octez-libs.lwt-result-stdlib
octez-libs.mec
octez-libs.micheline
octez-libs.plompiler
octez-libs.plonk
octez-libs.polynomial
octez-libs.requester
octez-libs.rpc
octez-libs.rpc-http
octez-libs.rpc-http-client
octez-libs.rpc-http-client-unix
octez-libs.rpc-http-server
octez-libs.srs-extraction
octez-libs.stdlib
octez-libs.stdlib-unix
octez-libs.test-helpers
octez-libs.tezos-context
octez-libs.tezos-gossipsub
octez-libs.tezos-p2p-services
octez-libs.tezos-sapling
octez-libs.tezos-workers
octez-libs.tezt-wrapper
octez-libs.tree-encoding
octez-libs.version
plonk_test
tezos_base_p2p_identity_file
tezos_base_unix
tezos_clic_unix
tezos_context_disk
tezos_context_dump
tezos_context_encoding
tezos_context_helpers
tezos_context_memory
tezos_context_merkle_proof_encoding
tezos_context_sigs
tezos_crypto_dal_octez_dal_config
tezos_version_parser
traced_functor_outputs
traced_sigs
traced_structs
traces
module Aggreg_circuit : sig ... end
module L = Plompiler.LibCircuit
exception Entry_not_in_table of string
exception Rest_not_null of string
module Input_commitment : sig ... end
type scalar = Kzg.Bls.Scalar.t
val scalar_t : Kzg.Bls.Scalar.t Repr.t
type circuit_map = Main_Pack.circuit_map
type prover_meta_pp = {
meta_pp : Main_Kzg.prover_public_parameters;
meta_solver : Plompiler.Solver.t;
public_input_size : int;
input_com_sizes : int list;
nb_proofs : int;
nb_rc_wires : int;
}
val prover_meta_pp_t : prover_meta_pp Repr.t
type verifier_meta_pp = {
meta_pp : Main_Kzg.verifier_public_parameters;
val verifier_meta_pp_t : verifier_meta_pp Repr.t
type prover_public_parameters = {
main_pp : Main_Pack.prover_public_parameters;
meta_pps : prover_meta_pp Kzg.SMap.t;
val prover_public_parameters_t : prover_public_parameters Repr.t
type verifier_public_parameters = {
main_pp : Main_Pack.verifier_public_parameters;
meta_pps : verifier_meta_pp Kzg.SMap.t;
val verifier_public_parameters_t : verifier_public_parameters Repr.t
type proof = {
main_proof : Main_Pack.proof;
meta_proofs : Main_Kzg.proof Kzg.SMap.t;
batch : Main_Kzg.scalar Kzg.SMap.t list;
batches : (Main_Kzg.scalar * int) Kzg.SMap.t list Kzg.SMap.t;
cms_answers : Main_Pack.PP.Answers_commitment.public Kzg.SMap.t;
cms_pi : Main_Pack.PP.Answers_commitment.public Kzg.SMap.t;
ids_batch : (Main_Kzg.scalar * int) Kzg.SMap.t;
t_answers : Main_Kzg.scalar list;
val proof_t : proof Repr.t
type circuit_prover_input = Main_Pack.circuit_prover_input = {
witness : scalar array;
input_commitments : Main_Pack.Input_commitment.t list;
val circuit_prover_input_t : circuit_prover_input Repr.t
type prover_inputs = circuit_prover_input list Kzg.SMap.t
val prover_inputs_t : circuit_prover_input list Kzg.SMap.t Repr.ty
type public_inputs = scalar list
val public_inputs_t : Kzg.Bls.Scalar.t list Repr.t
type circuit_verifier_input = {
public : public_inputs;
commitments : Input_commitment.public list list;
val circuit_verifier_input_t : circuit_verifier_input Repr.t
type verifier_inputs = circuit_verifier_input Kzg.SMap.t
val verifier_inputs_t : circuit_verifier_input Kzg.SMap.t Repr.ty
val to_verifier_inputs : prover_public_parameters -> Main_Pack.prover_inputs -> circuit_verifier_input Kzg.SMap.t
val update_prover_public_parameters : 'a Repr.ty -> 'a -> prover_public_parameters -> prover_public_parameters
val update_verifier_public_parameters : 'a Repr.ty -> 'a -> verifier_public_parameters -> verifier_public_parameters
val filter_prv_pp_circuits : prover_public_parameters -> 'a Kzg.SMap.t -> prover_public_parameters
val filter_vrf_pp_circuits : verifier_public_parameters -> 'a Kzg.SMap.t -> verifier_public_parameters
val cs_global : Plompiler.LibCircuit.cs_result Kzg.SMap.t ref
val input_commit_funcs : prover_public_parameters -> 'a list Kzg.SMap.t -> Main_Pack.input_commit_funcs Kzg.SMap.t
val input_commit : ?size:'a -> ?shift:'b -> prover_public_parameters -> 'c -> 'd
val meta_setup : zero_knowledge:bool -> srs:(Kzg.Bls.Srs.t * Kzg.Bls.Srs.t) -> main_prover_pp:Main_Pack.prover_public_parameters -> nb_batches:int -> Kzg.SMap.key -> (Plonk.Circuit.t * int) -> prover_meta_pp * verifier_meta_pp
val setup : zero_knowledge:bool -> Main_Pack.circuit_map -> srs:(Kzg.Bls.Srs.t * Kzg.Bls.Srs.t) -> prover_public_parameters * verifier_public_parameters
val meta_prove : main_prover_aux:Main_Pack.prover_aux -> meta_pps:prover_meta_pp Kzg.SMap.t -> inner_pi_map:Main_Pack.circuit_verifier_input Kzg.SMap.t -> transcript:Kzg.Utils.Transcript.t -> (Main_Pack.scalar * 'a) Kzg.SMap.t list Kzg.SMap.t -> Kzg.SMap.key -> 'b list -> Main_Kzg.proof
val meta_proof : prover_public_parameters -> Main_Pack.prover_inputs -> (Main_Pack.proof * Main_Pack.prover_aux) -> proof
val prove : prover_public_parameters -> inputs:prover_inputs -> proof
val meta_verify : transcript:Kzg.Utils.Transcript.t -> inputs:circuit_verifier_input Kzg.SMap.t -> proof:proof -> (Main_Kzg.scalar * Main_Kzg.scalar * Main_Kzg.scalar * Main_Kzg.scalar * Main_Kzg.scalar * Main_Kzg.scalar) -> Kzg.SMap.key -> verifier_meta_pp -> bool
val verify : verifier_public_parameters -> inputs:verifier_inputs -> proof -> bool
val scalar_encoding : Main_Pack.scalar Data_encoding.t
val data_encoding_of_repr : 'a Repr.t -> 'a Data_encoding.encoding
val proof_encoding : proof Data_encoding.encoding
val verifier_public_parameters_encoding : verifier_public_parameters Data_encoding.encoding
module Internal_for_tests : sig ... end