pub struct DefaultFqSponge<P: SWCurveConfig, SC: SpongeConstants> {
    pub sponge: ArithmeticSponge<P::BaseField, SC>,
    pub last_squeezed: Vec<u64>,
}Fields§
§sponge: ArithmeticSponge<P::BaseField, SC>§last_squeezed: Vec<u64>Implementations§
Source§impl<P: SWCurveConfig, SC: SpongeConstants> DefaultFqSponge<P, SC>where
    P::BaseField: PrimeField,
    <P::BaseField as PrimeField>::BigInt: Into<<P::ScalarField as PrimeField>::BigInt>,
 
impl<P: SWCurveConfig, SC: SpongeConstants> DefaultFqSponge<P, SC>where
    P::BaseField: PrimeField,
    <P::BaseField as PrimeField>::BigInt: Into<<P::ScalarField as PrimeField>::BigInt>,
pub fn squeeze_limbs(&mut self, num_limbs: usize) -> Vec<u64>
pub fn squeeze_field(&mut self) -> P::BaseField
pub fn squeeze(&mut self, num_limbs: usize) -> P::ScalarField
Trait Implementations§
Source§impl<P: Clone + SWCurveConfig, SC: Clone + SpongeConstants> Clone for DefaultFqSponge<P, SC>where
    P::BaseField: Clone,
 
impl<P: Clone + SWCurveConfig, SC: Clone + SpongeConstants> Clone for DefaultFqSponge<P, SC>where
    P::BaseField: Clone,
Source§fn clone(&self) -> DefaultFqSponge<P, SC>
 
fn clone(&self) -> DefaultFqSponge<P, SC>
Returns a duplicate 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<P: SWCurveConfig, SC: SpongeConstants> FqSponge<<P as CurveConfig>::BaseField, Affine<P>, <P as CurveConfig>::ScalarField> for DefaultFqSponge<P, SC>where
    P::BaseField: PrimeField,
    <P::BaseField as PrimeField>::BigInt: Into<<P::ScalarField as PrimeField>::BigInt>,
 
impl<P: SWCurveConfig, SC: SpongeConstants> FqSponge<<P as CurveConfig>::BaseField, Affine<P>, <P as CurveConfig>::ScalarField> for DefaultFqSponge<P, SC>where
    P::BaseField: PrimeField,
    <P::BaseField as PrimeField>::BigInt: Into<<P::ScalarField as PrimeField>::BigInt>,
Source§fn new(
    params: &'static ArithmeticSpongeParams<P::BaseField>,
) -> DefaultFqSponge<P, SC>
 
fn new( params: &'static ArithmeticSpongeParams<P::BaseField>, ) -> DefaultFqSponge<P, SC>
Creates a new sponge.
Source§fn absorb_g(&mut self, g: &[Affine<P>])
 
fn absorb_g(&mut self, g: &[Affine<P>])
Absorbs a base field point, that is a pair of 
Fq elements.
In the case of the point to infinity, the values (0, 0) are absorbed.Source§fn absorb_fq(&mut self, x: &[P::BaseField])
 
fn absorb_fq(&mut self, x: &[P::BaseField])
Absorbs a base field element. This operation is the most
straightforward and calls the underlying sponge directly.
Source§fn absorb_fr(&mut self, x: &[P::ScalarField])
 
fn absorb_fr(&mut self, x: &[P::ScalarField])
Absorbs an element of the scalar field 
Fr — it is done
by converting the element to the base field first.Source§fn digest(self) -> P::ScalarField
 
fn digest(self) -> P::ScalarField
Returns a scalar field digest using the binary representation technique.
Source§fn digest_fq(self) -> P::BaseField
 
fn digest_fq(self) -> P::BaseField
Returns a base field digest by squeezing the underlying sponge directly.
Source§fn challenge(&mut self) -> P::ScalarField
 
fn challenge(&mut self) -> P::ScalarField
Squeeze out a challenge in the scalar field. Implemented by
squeezing out base points and then converting them to a scalar
field element using binary representation.
Source§fn challenge_fq(&mut self) -> P::BaseField
 
fn challenge_fq(&mut self) -> P::BaseField
Squeeze out a base field challenge. This operation is the most
direct and calls the underlying sponge.
Auto Trait Implementations§
impl<P, SC> Freeze for DefaultFqSponge<P, SC>
impl<P, SC> RefUnwindSafe for DefaultFqSponge<P, SC>where
    SC: RefUnwindSafe,
    <P as CurveConfig>::BaseField: RefUnwindSafe,
impl<P, SC> Send for DefaultFqSponge<P, SC>where
    SC: Send,
impl<P, SC> Sync for DefaultFqSponge<P, SC>where
    SC: Sync,
impl<P, SC> Unpin for DefaultFqSponge<P, SC>
impl<P, SC> UnwindSafe for DefaultFqSponge<P, SC>
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