Skip to main content

Poseidon1Constants

Struct Poseidon1Constants 

Source
pub struct Poseidon1Constants<F, const WIDTH: usize> {
    pub rounds_f: usize,
    pub rounds_p: usize,
    pub mds_circ_col: [i64; WIDTH],
    pub round_constants: Vec<[F; WIDTH]>,
}
Expand description

Raw Poseidon1 parameters before the sparse matrix optimization.

These are the “textbook” parameters as generated by the Grain LFSR or any other parameter-generation script. They are transformed into the optimized sparse form used at runtime.

§Round Constant Layout

Constants are stored in a flat array with three consecutive sections:

  ┌──────────────┬──────────────────┬──────────────────┐
  │ initial full  │  partial rounds  │  terminal full   │
  │ (RF/2 items)  │  (RP items)      │  (RF/2 items)    │
  └──────────────┴──────────────────┴──────────────────┘

Each entry is a WIDTH-sized vector (one constant per state element per round).

Fields§

§rounds_f: usize

Total number of full rounds (split equally between initial and terminal).

§rounds_p: usize

Number of partial rounds.

§mds_circ_col: [i64; WIDTH]

First column of the circulant MDS matrix, stored as signed integers.

This matches the representation used by the MDS crate, so concrete fields can pass their verified constants directly without duplication. During initialization, the dense form is expanded once for the sparse decomposition, then discarded.

§round_constants: Vec<[F; WIDTH]>

Round constants, one WIDTH-sized vector per round.

Total length = rounds_f + rounds_p.

Implementations§

Source§

impl<F: PrimeField, const WIDTH: usize> Poseidon1Constants<F, WIDTH>

Source

pub fn to_optimized( &self, ) -> (FullRoundConstants<F, WIDTH>, PartialRoundConstants<F, WIDTH>)

Compute the optimized sparse-form constants from these raw parameters.

This performs two transformations:

  1. Sparse matrix decomposition: factors the dense MDS matrix into one dense transition matrix and several sparse matrices. Each sparse matrix is parameterized by two vectors of length WIDTH-1.

  2. Round constant compression: via backward substitution through the inverse MDS matrix, reduces each partial round’s full constant vector to a single scalar, except for the first partial round.

Trait Implementations§

Source§

impl<F: Clone, const WIDTH: usize> Clone for Poseidon1Constants<F, WIDTH>

Source§

fn clone(&self) -> Poseidon1Constants<F, WIDTH>

Returns a duplicate 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: Debug, const WIDTH: usize> Debug for Poseidon1Constants<F, WIDTH>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<F, const WIDTH: usize> Freeze for Poseidon1Constants<F, WIDTH>

§

impl<F, const WIDTH: usize> RefUnwindSafe for Poseidon1Constants<F, WIDTH>
where F: RefUnwindSafe,

§

impl<F, const WIDTH: usize> Send for Poseidon1Constants<F, WIDTH>
where F: Send,

§

impl<F, const WIDTH: usize> Sync for Poseidon1Constants<F, WIDTH>
where F: Sync,

§

impl<F, const WIDTH: usize> Unpin for Poseidon1Constants<F, WIDTH>
where F: Unpin,

§

impl<F, const WIDTH: usize> UnsafeUnpin for Poseidon1Constants<F, WIDTH>

§

impl<F, const WIDTH: usize> UnwindSafe for Poseidon1Constants<F, WIDTH>
where F: 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§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

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

Source§

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, U> TryFrom<U> for T
where U: Into<T>,

Source§

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>,

Source§

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> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more