pub struct FieldMerkleTree<F, W, M, const DIGEST_ELEMS: usize> {
pub leaves: Vec<M>,
pub digest_layers: Vec<Vec<[W; DIGEST_ELEMS]>>,
/* private fields */
}
Expand description
A binary Merkle tree for field data. It has leaves of type F
and digests of type
[W; DIGEST_ELEMS]
.
This generally shouldn’t be used directly. If you’re using a Merkle tree as an MMCS,
see FieldMerkleTreeMmcs
.
Fields§
§leaves: Vec<M>
§digest_layers: Vec<Vec<[W; DIGEST_ELEMS]>>
Implementations§
Source§impl<F: Clone + Send + Sync, W: Clone, M: Matrix<F>, const DIGEST_ELEMS: usize> FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F: Clone + Send + Sync, W: Clone, M: Matrix<F>, const DIGEST_ELEMS: usize> FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Sourcepub fn new<P, PW, H, C>(h: &H, c: &C, leaves: Vec<M>) -> Selfwhere
P: PackedField<Scalar = F>,
PW: PackedValue<Value = W>,
H: CryptographicHasher<F, [W; DIGEST_ELEMS]> + CryptographicHasher<P, [PW; DIGEST_ELEMS]> + Sync,
C: PseudoCompressionFunction<[W; DIGEST_ELEMS], 2> + PseudoCompressionFunction<[PW; DIGEST_ELEMS], 2> + Sync,
pub fn new<P, PW, H, C>(h: &H, c: &C, leaves: Vec<M>) -> Selfwhere
P: PackedField<Scalar = F>,
PW: PackedValue<Value = W>,
H: CryptographicHasher<F, [W; DIGEST_ELEMS]> + CryptographicHasher<P, [PW; DIGEST_ELEMS]> + Sync,
C: PseudoCompressionFunction<[W; DIGEST_ELEMS], 2> + PseudoCompressionFunction<[PW; DIGEST_ELEMS], 2> + Sync,
Matrix heights need not be powers of two. However, if the heights of two given matrices round up to the same power of two, they must be equal.
pub fn from_parts( leaves: Vec<M>, digest_layers: Vec<Vec<[W; DIGEST_ELEMS]>>, ) -> Self
pub fn root(&self) -> Hash<F, W, DIGEST_ELEMS>where
W: Copy,
Trait Implementations§
Source§impl<F: Clone, W: Clone, M: Clone, const DIGEST_ELEMS: usize> Clone for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F: Clone, W: Clone, M: Clone, const DIGEST_ELEMS: usize> Clone for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Source§fn clone(&self) -> FieldMerkleTree<F, W, M, DIGEST_ELEMS>
fn clone(&self) -> FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<F: Debug, W: Debug, M: Debug, const DIGEST_ELEMS: usize> Debug for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F: Debug, W: Debug, M: Debug, const DIGEST_ELEMS: usize> Debug for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Source§impl<'de, F, W, M, const DIGEST_ELEMS: usize> Deserialize<'de> for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<'de, F, W, M, const DIGEST_ELEMS: usize> Deserialize<'de> for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<F, W, M, const DIGEST_ELEMS: usize> Serialize for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F, W, M, const DIGEST_ELEMS: usize> Serialize for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Auto Trait Implementations§
impl<F, W, M, const DIGEST_ELEMS: usize> Freeze for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F, W, M, const DIGEST_ELEMS: usize> RefUnwindSafe for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F, W, M, const DIGEST_ELEMS: usize> Send for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F, W, M, const DIGEST_ELEMS: usize> Sync for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F, W, M, const DIGEST_ELEMS: usize> Unpin for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
impl<F, W, M, const DIGEST_ELEMS: usize> UnwindSafe for FieldMerkleTree<F, W, M, DIGEST_ELEMS>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more