Struct snarkvm_wasm::PedersenCRH[][src]

pub struct PedersenCRH<G, S> where
    G: Group,
    S: PedersenSize
{ pub parameters: PedersenCRHParameters<G, S>, }

Fields

parameters: PedersenCRHParameters<G, S>

Trait Implementations

impl<G, S> CRH for PedersenCRH<G, S> where
    G: Group,
    S: PedersenSize
[src]

type Output = G

type Parameters = PedersenCRHParameters<G, S>

pub const INPUT_SIZE_BITS: usize[src]

pub fn setup<R>(rng: &mut R) -> PedersenCRH<G, S> where
    R: Rng
[src]

pub fn hash(
    &self,
    input: &[u8]
) -> Result<<PedersenCRH<G, S> as CRH>::Output, CRHError>
[src]

pub fn parameters(&self) -> &<PedersenCRH<G, S> as CRH>::Parameters[src]

impl<F, G, GG, S> CRHGadget<PedersenCRH<G, S>, F> for PedersenCRHGadget<G, F, GG> where
    G: Group,
    S: PedersenSize,
    F: Field,
    GG: GroupGadget<G, F>, 
[src]

type OutputGadget = GG

type ParametersGadget = PedersenCRHParametersGadget<G, S, F, GG>

pub fn check_evaluation_gadget<CS>(
    cs: CS,
    parameters: &<PedersenCRHGadget<G, F, GG> as CRHGadget<PedersenCRH<G, S>, F>>::ParametersGadget,
    input: Vec<UInt8, Global>
) -> Result<<PedersenCRHGadget<G, F, GG> as CRHGadget<PedersenCRH<G, S>, F>>::OutputGadget, SynthesisError> where
    CS: ConstraintSystem<F>, 
[src]

impl<G, S> Clone for PedersenCRH<G, S> where
    G: Clone + Group,
    S: Clone + PedersenSize
[src]

pub fn clone(&self) -> PedersenCRH<G, S>[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl<G, S> Debug for PedersenCRH<G, S> where
    G: Debug + Group,
    S: Debug + PedersenSize
[src]

pub fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

Formats the value using the given formatter. Read more

impl<G, S> From<PedersenCRHParameters<G, S>> for PedersenCRH<G, S> where
    G: Group,
    S: PedersenSize
[src]

pub fn from(parameters: PedersenCRHParameters<G, S>) -> PedersenCRH<G, S>[src]

Performs the conversion.

impl<F, G, GG, S> MaskedCRHGadget<PedersenCRH<G, S>, F> for PedersenCRHGadget<G, F, GG> where
    G: Group,
    S: PedersenSize,
    F: PrimeField,
    GG: GroupGadget<G, F>, 
[src]

pub fn check_evaluation_gadget_masked<CS>(
    cs: CS,
    parameters: &<PedersenCRHGadget<G, F, GG> as CRHGadget<PedersenCRH<G, S>, F>>::ParametersGadget,
    input: Vec<UInt8, Global>,
    mask_parameters: &<PedersenCRHGadget<G, F, GG> as CRHGadget<PedersenCRH<G, S>, F>>::ParametersGadget,
    mask: Vec<UInt8, Global>
) -> Result<<PedersenCRHGadget<G, F, GG> as CRHGadget<PedersenCRH<G, S>, F>>::OutputGadget, SynthesisError> where
    CS: ConstraintSystem<F>, 
[src]

Evaluates a masked Pedersen hash on the given input using the given mask. The algorithm is based on the description in https://eprint.iacr.org/2020/190.pdf, which relies on the homomorphic properties of Pedersen hashes. First, the mask is extended to ensure constant hardness - for each bit, 0 => 01, 1 => 10. Then, denoting input bits as m_i, mask bits as p_i and bases as h_i, computes sum of (g_i * 1[p_i = 0] + g_i^{-1} * 1[p_i = 1])^{m_i \xor p_i} for all i. Finally, the hash of the mask itself, being sum of h_i^{p_i} for all i, is added to the computed sum. This algorithm ensures that each bit in the hash is affected by the mask and that the final hash remains the same as if no mask was used.

fn extend_mask<CS>(
    CS,
    mask: &[UInt8]
) -> Result<Vec<UInt8, Global>, SynthesisError> where
    CS: ConstraintSystem<F>, 
[src]

Extends the mask such that 0 => 01, 1 => 10.

impl<G, S> Ord for PedersenCRH<G, S> where
    G: Ord + Group,
    S: Ord + PedersenSize
[src]

pub fn cmp(&self, other: &PedersenCRH<G, S>) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl<G, S> PartialEq<PedersenCRH<G, S>> for PedersenCRH<G, S> where
    G: PartialEq<G> + Group,
    S: PartialEq<S> + PedersenSize
[src]

pub fn eq(&self, other: &PedersenCRH<G, S>) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

pub fn ne(&self, other: &PedersenCRH<G, S>) -> bool[src]

This method tests for !=.

impl<G, S> PartialOrd<PedersenCRH<G, S>> for PedersenCRH<G, S> where
    G: PartialOrd<G> + Group,
    S: PartialOrd<S> + PedersenSize
[src]

pub fn partial_cmp(&self, other: &PedersenCRH<G, S>) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl<F, G, S> ToConstraintField<F> for PedersenCRH<G, S> where
    G: Group + ToConstraintField<F>,
    S: PedersenSize,
    F: Field
[src]

impl<G, S> Eq for PedersenCRH<G, S> where
    G: Eq + Group,
    S: Eq + PedersenSize
[src]

impl<G, S> StructuralEq for PedersenCRH<G, S> where
    G: Group,
    S: PedersenSize
[src]

impl<G, S> StructuralPartialEq for PedersenCRH<G, S> where
    G: Group,
    S: PedersenSize
[src]

Auto Trait Implementations

impl<G, S> RefUnwindSafe for PedersenCRH<G, S> where
    G: RefUnwindSafe,
    S: RefUnwindSafe

impl<G, S> Send for PedersenCRH<G, S> where
    S: Send

impl<G, S> Sync for PedersenCRH<G, S> where
    S: Sync

impl<G, S> Unpin for PedersenCRH<G, S> where
    G: Unpin,
    S: Unpin

impl<G, S> UnwindSafe for PedersenCRH<G, S> where
    G: UnwindSafe,
    S: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<Q, K> Equivalent<K> for Q where
    K: Borrow<Q> + ?Sized,
    Q: Eq + ?Sized
[src]

pub fn equivalent(&self, key: &K) -> bool[src]

Compare self to key and return true if they are equal.

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> Pointable for T

pub const ALIGN: usize

The alignment of pointer.

type Init = T

The type for initializers.

pub unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more

pub unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more

pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more

pub unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

Creates owned data from borrowed data, usually by cloning. Read more

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 

pub fn vzip(self) -> V