Struct neptune::poseidon::PoseidonConstants

source ·
pub struct PoseidonConstants<F, A>
where F: PrimeField, A: Arity<F>,
{ pub mds_matrices: MdsMatrices<F>, pub round_constants: Option<Vec<F>>, pub compressed_round_constants: Vec<F>, pub pre_sparse_matrix: Vec<Vec<F>>, pub sparse_matrixes: Vec<SparseMatrix<F>>, pub strength: Strength, pub domain_tag: F, pub full_rounds: usize, pub half_full_rounds: usize, pub partial_rounds: usize, pub hash_type: HashType<F, A>, /* private fields */ }
Expand description

Holds constant values required for further Poseidon hashing. It contains MDS matrices, round constants and numbers, parameters that specify security level (Strength) and domain separation (HashType). Additional constants related to optimizations are also included.

For correct operation, PoseidonConstants instance should be parameterized with the same ff::PrimeField and Arity as Poseidon instance that consumes it.

See original Poseidon paper for more details.

Fields§

§mds_matrices: MdsMatrices<F>§round_constants: Option<Vec<F>>§compressed_round_constants: Vec<F>§pre_sparse_matrix: Vec<Vec<F>>§sparse_matrixes: Vec<SparseMatrix<F>>§strength: Strength§domain_tag: F

The domain tag is the first element of a Poseidon permutation. This extra element is necessary for 128-bit security.

§full_rounds: usize§half_full_rounds: usize§partial_rounds: usize§hash_type: HashType<F, A>

Implementations§

source§

impl<F, A> PoseidonConstants<F, A>
where F: PrimeField, A: Arity<F>,

source

pub fn new() -> Self

Generates new instance of PoseidonConstants suitable for both optimized / non-optimized hashing with following default parameters:

  • 128 bit of security;
  • Merkle Tree (where all leafs are presented) domain separation (HashType).
§Example
use neptune::poseidon::PoseidonConstants;
use neptune::Strength;
use neptune::hash_type::HashType;
use pasta_curves::Fp;
use generic_array::typenum::U2;

let constants: PoseidonConstants<Fp, U2> = PoseidonConstants::new();

assert_eq!(constants.strength, Strength::Standard);
assert_eq!(constants.hash_type, HashType::MerkleTree);
source

pub fn new_constant_length(length: usize) -> Self

Generates new instance of PoseidonConstants suitable for both optimized / non-optimized hashing of constant-size preimages with following parameters:

  • 128 bit of security;
  • Constant-Input-Length Hashing domain separation (HashType).

Instantiated PoseidonConstants still calculates internal constants based on Arity, but calculation of HashType::domain_tag is based on input length.

§Example
use neptune::poseidon::PoseidonConstants;
use neptune::Strength;
use neptune::hash_type::HashType;
use pasta_curves::Fp;
use generic_array::typenum::U2;

let preimage_length = 2usize;
let constants: PoseidonConstants<Fp, U2> = PoseidonConstants::new_constant_length(preimage_length);

assert_eq!(constants.strength, Strength::Standard);
assert_eq!(constants.hash_type, HashType::<Fp, U2>::ConstantLength(preimage_length));
source

pub fn with_length(&self, length: usize) -> Self

Creates new instance of PoseidonConstants from already defined one with recomputed domain tag.

It is assumed that input length is equal or less than Arity.

§Example
use neptune::poseidon::PoseidonConstants;
use neptune::Strength;
use neptune::hash_type::HashType;
use pasta_curves::Fp;
use generic_array::typenum::U8;

let preimage_length = 2usize;
let constants: PoseidonConstants<Fp, U8> = PoseidonConstants::new_constant_length(preimage_length);
let constants: PoseidonConstants<Fp, U8> = constants.with_length(preimage_length - 2);

assert_eq!(constants.strength, Strength::Standard);
assert_eq!(constants.hash_type, HashType::<Fp, U8>::ConstantLength(preimage_length - 2));
source

pub fn new_with_strength(strength: Strength) -> Self

Generates new instance of PoseidonConstants suitable for both optimized / non-optimized hashing with Merkle Tree (where all leafs are presented) domain separation (HashType) custom security level (Strength).

§Example
use neptune::poseidon::PoseidonConstants;
use neptune::Strength;
use neptune::hash_type::HashType;
use pasta_curves::Fp;
use generic_array::typenum::U2;

let security_level = Strength::Strengthened;
let constants: PoseidonConstants<Fp, U2> = PoseidonConstants::new_with_strength(security_level);

assert_eq!(constants.strength, Strength::Strengthened);
assert_eq!(constants.hash_type, HashType::MerkleTree);
source

pub fn new_with_strength_and_type( strength: Strength, hash_type: HashType<F, A>, ) -> Self

Generates new instance of PoseidonConstants suitable for both optimized / non-optimized hashing with custom domain separation (HashType) and custom security level (Strength).

§Example
use neptune::poseidon::PoseidonConstants;
use neptune::Strength;
use neptune::hash_type::HashType;
use pasta_curves::Fp;
use generic_array::typenum::U2;

let domain_separation = HashType::Encryption;
let security_level = Strength::Strengthened;
let constants: PoseidonConstants<Fp, U2> = PoseidonConstants::new_with_strength_and_type(security_level, domain_separation);

assert_eq!(constants.strength, Strength::Strengthened);
assert_eq!(constants.hash_type, HashType::Encryption);
source

pub fn arity(&self) -> usize

Returns the Arity value represented as usize.

§Example
use neptune::poseidon::PoseidonConstants;
use pasta_curves::Fp;
use generic_array::typenum::U8;

let constants: PoseidonConstants<Fp, U8> = PoseidonConstants::new();

assert_eq!(constants.arity(), 8usize);
source

pub fn width(&self) -> usize

Returns width value represented as usize. It equals to Arity + 1.

§Example
use neptune::poseidon::PoseidonConstants;
use pasta_curves::Fp;
use generic_array::typenum::U8;

let constants: PoseidonConstants<Fp, U8> = PoseidonConstants::new();

assert_eq!(constants.width(), 8 + 1);

Trait Implementations§

source§

impl<F, A> Clone for PoseidonConstants<F, A>
where F: PrimeField + Clone, A: Arity<F> + Clone,

source§

fn clone(&self) -> PoseidonConstants<F, A>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<F, A> Debug for PoseidonConstants<F, A>
where F: PrimeField + Debug, A: Arity<F> + Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<F, A> Default for PoseidonConstants<F, A>
where F: PrimeField, A: Arity<F>,

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl<'de, F, A> Deserialize<'de> for PoseidonConstants<F, A>
where F: PrimeField + Deserialize<'de>, A: Arity<F>,

source§

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, A> PartialEq for PoseidonConstants<F, A>
where F: PrimeField + PartialEq, A: Arity<F> + PartialEq,

source§

fn eq(&self, other: &PoseidonConstants<F, A>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<F, A> Serialize for PoseidonConstants<F, A>
where F: PrimeField + Serialize, A: Arity<F>,

source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<F, A> StructuralPartialEq for PoseidonConstants<F, A>
where F: PrimeField, A: Arity<F>,

Auto Trait Implementations§

§

impl<F, A> Freeze for PoseidonConstants<F, A>
where F: Freeze, A: Freeze,

§

impl<F, A> RefUnwindSafe for PoseidonConstants<F, A>

§

impl<F, A> Send for PoseidonConstants<F, A>
where A: Send,

§

impl<F, A> Sync for PoseidonConstants<F, A>
where A: Sync,

§

impl<F, A> Unpin for PoseidonConstants<F, A>
where F: Unpin, A: Unpin,

§

impl<F, A> UnwindSafe for PoseidonConstants<F, A>
where F: UnwindSafe, A: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> Conv for T

source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<T> FmtForward for T

source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Pipe for T
where T: ?Sized,

source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> Tap for T

source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

impl<T> TryConv for T

source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

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

Performs the conversion.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,