package octez-plonk

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Module Pack.Pack_implSource

Sourcetype scalar = Plonk.Bls.Scalar.t
Sourcetype prover_public_parameters = {
  1. length : int;
  2. srs2_t : Plonk.Bls.G2.t array;
  3. g1_t : Plonk.Bls.G1.t;
}
Sourceval prover_public_parameters_t : prover_public_parameters Repr.t
Sourcetype verifier_public_parameters = Plonk.Bls.G1.t
Sourceval verifier_public_parameters_t : Plonk.Bls.G1.t Repr.t
Sourcetype commitment = {
  1. cmt_t : Plonk.Bls.GT.t;
  2. cmt_len : int;
}
Sourceval commitment_t : commitment Repr.t
Sourcetype randomness = Plonk.Bls.Scalar.t
Sourcetype packed = Plonk.Bls.G1.t
Sourcetype ipa_proof = {
  1. t_Ls : Plonk.Bls.GT.t array;
  2. t_Rs : Plonk.Bls.GT.t array;
  3. r_Ls : Plonk.Bls.G1.t array;
  4. r_Rs : Plonk.Bls.G1.t array;
  5. a0 : Plonk.Bls.G1.t;
  6. t0 : Plonk.Bls.G2.t;
}
Sourceval ipa_proof_t : ipa_proof Repr.t
Sourceval empty_ipa_proof : int -> ipa_proof
Sourcetype kzg_proof = Plonk.Bls.G2.t
Sourceval kzg_proof_t : Plonk.Bls.G2.t Repr.t
Sourcetype proof = ipa_proof * kzg_proof
Sourcetype transcript = Bytes.t
Sourcetype setup_params = int
Sourceval hash : transcript:bytes -> random:(?state:Random.State.t -> unit -> 'a) -> ?g1s:Plonk.Bls.G1.t array list -> ?g2s:Plonk.Bls.G2.t array list -> ?gts:Plonk.Bls.GT.t array list -> ?scalars:Plonk.Bls.Scalar.t array list -> unit -> 'a * bytes
Sourceval ip_pairing : Bls12_381.G1.t array -> Bls12_381.G2.t array -> Plonk.Bls.GT.t
Sourceval get_setup_params : prover_public_parameters -> int
Sourceval public_parameters_to_bytes : prover_public_parameters -> Bytes.t
Sourceval commit : prover_public_parameters -> Bls12_381.G1.t array -> commitment
Sourceval commitment_cardinal : commitment -> int
Sourceval partial_commit : relevant_positions:Int.t list -> prover_public_parameters -> Bls12_381.G1.t array -> commitment
Sourceval bytes_of_commitment : commitment -> bytes
Sourceval empty_commitment : commitment
Sourceval pack : Plonk.Bls.G1.Scalar.t array -> Plonk.Bls.G1.t array -> Plonk.Bls.G1.t
Sourceval array_split_in_half : 'a array -> 'a array * 'a array
Sourceval array_padded_with_zero : 'a array -> int -> 'a -> 'a array
Sourceval prove_but_not_pack : prover_public_parameters -> bytes -> Plonk.Bls.Scalar.t -> Plonk.Bls.G1.t array -> Plonk.Bls.G1.t -> (ipa_proof * Plonk.Bls.G2.t) * bytes
Sourceval prove_single : prover_public_parameters -> bytes -> Plonk.Bls.Scalar.t -> Plonk.Bls.G1.t array -> (Plonk.Bls.G1.t * (ipa_proof * Plonk.Bls.G2.t)) * bytes
Sourceval prove : prover_public_parameters -> bytes -> Plonk.Bls.Scalar.t -> Plonk.Bls.G1.t array list -> (Plonk.Bls.G1.t list * (ipa_proof * Plonk.Bls.G2.t)) * bytes
Sourceval verify_single : Plonk.Bls.G1.t -> bytes -> commitment -> Plonk.Bls.Scalar.t -> (Plonk.Bls.G1.t * (ipa_proof * Plonk.Bls.G2.t)) -> bool * bytes
Sourceval verify : Plonk.Bls.G1.t -> bytes -> commitment list -> Plonk.Bls.Scalar.t -> (Plonk.Bls.G1.t list * (ipa_proof * Plonk.Bls.G2.t)) -> bool * bytes
OCaml

Innovation. Community. Security.