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>

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>

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

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

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

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

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.

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

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

impl<G, S> PartialOrd<PedersenCRH<G, S>> for PedersenCRH<G, S> where
    G: PartialOrd<G> + Group,
    S: PedersenSize + PartialOrd<S>, 
[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]

impl<F, G, S> ToConstraintField<F> for PedersenCRH<G, S> where
    G: Group + ToConstraintField<F>,
    S: PedersenSize,
    F: Field
[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]

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

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

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

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

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

impl<T> Pointable for T

type Init = T

The type for initializers.

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.

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.

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.

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