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§
Sourcefn optimal_verify_layer(&self, n_queries: usize, tree_depth: usize) -> usize
fn optimal_verify_layer(&self, n_queries: usize, tree_depth: usize) -> usize
Returns the optimal layer that the verifier should verify only once.
Sourcefn proof_size(
&self,
len: usize,
n_queries: usize,
layer_depth: usize,
) -> Result<usize, Error>
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 vectorn_queries
- the number of opening queries
Sourcefn verify_vector(
&self,
root: &Self::Digest,
data: &[T],
batch_size: usize,
) -> Result<(), Error>
fn verify_vector( &self, root: &Self::Digest, data: &[T], batch_size: usize, ) -> Result<(), Error>
Verify the opening of the full vector.
Sourcefn verify_layer(
&self,
root: &Self::Digest,
layer_depth: usize,
layer_digests: &[Self::Digest],
) -> Result<(), Error>
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.
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.