binius_core::merkle_tree

Trait MerkleTreeScheme

Source
pub trait MerkleTreeScheme<T>: Sync {
    type Digest: Clone + PartialEq + Eq;

    // Required methods
    fn optimal_verify_layer(&self, n_queries: usize, tree_depth: usize) -> usize;
    fn proof_size(
        &self,
        len: usize,
        n_queries: usize,
        layer_depth: usize,
    ) -> Result<usize, Error>;
    fn verify_vector(
        &self,
        root: &Self::Digest,
        data: &[T],
        batch_size: usize,
    ) -> Result<(), Error>;
    fn verify_layer(
        &self,
        root: &Self::Digest,
        layer_depth: usize,
        layer_digests: &[Self::Digest],
    ) -> Result<(), Error>;
    fn verify_opening<Proof: CanRead>(
        &self,
        index: usize,
        values: &[T],
        layer_depth: usize,
        tree_depth: usize,
        layer_digests: &[Self::Digest],
        proof: Proof,
    ) -> Result<(), Error>;
}
Expand description

A Merkle tree scheme.

Required Associated Types§

Required Methods§

Source

fn optimal_verify_layer(&self, n_queries: usize, tree_depth: usize) -> usize

Returns the optimal layer that the verifier should verify only once.

Source

fn proof_size( &self, len: usize, n_queries: usize, layer_depth: usize, ) -> Result<usize, Error>

Returns the total byte-size of a proof for multiple opening queries.

§Arguments
  • len - the length of the committed vector
  • n_queries - the number of opening queries
Source

fn verify_vector( &self, root: &Self::Digest, data: &[T], batch_size: usize, ) -> Result<(), Error>

Verify the opening of the full vector.

Source

fn verify_layer( &self, root: &Self::Digest, layer_depth: usize, layer_digests: &[Self::Digest], ) -> Result<(), Error>

Verify a given layer of the Merkle tree.

When a protocol requires verification of many openings at independent and randomly sampled indices, it is more efficient for the verifier to verifier an internal layer once, then verify all openings with respect to that layer.

Source

fn verify_opening<Proof: CanRead>( &self, index: usize, values: &[T], layer_depth: usize, tree_depth: usize, layer_digests: &[Self::Digest], proof: Proof, ) -> Result<(), Error>

Verify an opening proof for an entry in a committed vector at the given index.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

Source§

impl<F, H, C> MerkleTreeScheme<F> for BinaryMerkleTreeScheme<F, H, C>
where F: TowerField, H: Digest + BlockSizeUser, C: PseudoCompressionFunction<Output<H>, 2> + Sync,

Source§

type Digest = GenericArray<u8, <H as OutputSizeUser>::OutputSize>