Struct Goldilocks

Source
pub struct Goldilocks { /* private fields */ }
Expand description

The prime field known as Goldilocks, defined as F_p where p = 2^64 - 2^32 + 1.

Note that the safety of deriving Serialize and Deserialize relies on the fact that the internal value can be any u64.

Trait Implementations§

Source§

impl Add for Goldilocks

Source§

type Output = Goldilocks

The resulting type after applying the + operator.
Source§

fn add(self, rhs: Self) -> Self

Performs the + operation. Read more
Source§

impl AddAssign for Goldilocks

Source§

fn add_assign(&mut self, rhs: Self)

Performs the += operation. Read more
Source§

impl BinomiallyExtendable<2> for Goldilocks

Source§

const W: Self

Source§

const DTH_ROOT: Self

Source§

const EXT_GENERATOR: [Self; 2]

Source§

impl Clone for Goldilocks

Source§

fn clone(&self) -> Goldilocks

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 Convolve<Goldilocks, i128, i64, i128> for SmallConvolveGoldilocks

Source§

fn read(input: Goldilocks) -> i128

Return the lift of a Goldilocks element, 0 <= input.value <= P < 2^64. We widen immediately, since some valid Goldilocks elements don’t fit in an i64, and since in any case overflow can occur for even the smallest convolutions.

Source§

fn parity_dot<const N: usize>(u: [i128; N], v: [i64; N]) -> i128

For a convolution of size N, |x| < N * 2^64 and (as per the assumption above), |y| < 2^51. So the product is at most N * 2^115 which will not overflow for N <= 16. We widen y at this point to perform the multiplication.

Source§

fn reduce(z: i128) -> Goldilocks

The assumptions above mean z < N^2 * 2^115, which is at most 2^123 when N <= 16.

NB: Even though intermediate values could be negative, the output must be non-negative since the inputs were non-negative.

Source§

fn apply<const N: usize, C>(lhs: [F; N], rhs: [U; N], conv: C) -> [F; N]
where C: Fn([T; N], [U; N], &mut [V]),

Convolve lhs and rhs. Read more
Source§

fn conv3(lhs: [T; 3], rhs: [U; 3], output: &mut [V])

Source§

fn negacyclic_conv3(lhs: [T; 3], rhs: [U; 3], output: &mut [V])

Source§

fn conv4(lhs: [T; 4], rhs: [U; 4], output: &mut [V])

Source§

fn negacyclic_conv4(lhs: [T; 4], rhs: [U; 4], output: &mut [V])

Source§

fn conv6(lhs: [T; 6], rhs: [U; 6], output: &mut [V])

Source§

fn negacyclic_conv6(lhs: [T; 6], rhs: [U; 6], output: &mut [V])

Source§

fn conv8(lhs: [T; 8], rhs: [U; 8], output: &mut [V])

Source§

fn negacyclic_conv8(lhs: [T; 8], rhs: [U; 8], output: &mut [V])

Source§

fn conv12(lhs: [T; 12], rhs: [U; 12], output: &mut [V])

Source§

fn negacyclic_conv12(lhs: [T; 12], rhs: [U; 12], output: &mut [V])

Source§

fn conv16(lhs: [T; 16], rhs: [U; 16], output: &mut [V])

Source§

fn negacyclic_conv16(lhs: [T; 16], rhs: [U; 16], output: &mut [V])

Source§

fn conv24(lhs: [T; 24], rhs: [U; 24], output: &mut [V])

Source§

fn conv32(lhs: [T; 32], rhs: [U; 32], output: &mut [V])

Source§

fn negacyclic_conv32(lhs: [T; 32], rhs: [U; 32], output: &mut [V])

Source§

fn conv64(lhs: [T; 64], rhs: [U; 64], output: &mut [V])

Source§

impl Debug for Goldilocks

Source§

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

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

impl Default for Goldilocks

Source§

fn default() -> Goldilocks

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

impl<'de> Deserialize<'de> for Goldilocks

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 Display for Goldilocks

Source§

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

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

impl Distribution<Goldilocks> for Standard

Source§

fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> Goldilocks

Generate a random value of T, using rng as the source of randomness.
Source§

fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T>
where R: Rng, Self: Sized,

Create an iterator that generates random values of T, using rng as the source of randomness. Read more
Source§

fn map<F, S>(self, func: F) -> DistMap<Self, F, T, S>
where F: Fn(T) -> S, Self: Sized,

Create a distribution of values of ‘S’ by mapping the output of Self through the closure F Read more
Source§

impl Div for Goldilocks

Source§

type Output = Goldilocks

The resulting type after applying the / operator.
Source§

fn div(self, rhs: Self) -> Self

Performs the / operation. Read more
Source§

impl Field for Goldilocks

Source§

const GENERATOR: Self

A generator of this field’s entire multiplicative group.
Source§

type Packing = Goldilocks

Source§

fn is_zero(&self) -> bool

Source§

fn exp_u64_generic<FA: FieldAlgebra<F = Self>>(val: FA, power: u64) -> FA

Exponentiation by a u64 power. This is similar to exp_u64, but more general in that it can be used with FieldAlgebras, not just this concrete field. Read more
Source§

fn try_inverse(&self) -> Option<Self>

The multiplicative inverse of this field element, if it exists. Read more
Source§

fn halve(&self) -> Self

Computes input/2. Should be overwritten by most field implementations to use bitshifts. Will error if the field characteristic is 2.
Source§

fn order() -> BigUint

Source§

fn is_one(&self) -> bool

Source§

fn div_2exp_u64(&self, exp: u64) -> Self

self / 2^exp
Source§

fn inverse(&self) -> Self

Source§

fn multiplicative_group_factors() -> Vec<(BigUint, usize)>

A list of (factor, exponent) pairs.
Source§

fn bits() -> usize

Source§

impl FieldAlgebra for Goldilocks

Source§

const ZERO: Self

The additive identity of the algebra. Read more
Source§

const ONE: Self

The multiplicative identity of the Algebra Read more
Source§

const TWO: Self

The element in the algebra given by ONE + ONE. Read more
Source§

const NEG_ONE: Self

The element in the algebra given by -ONE. Read more
Source§

type F = Goldilocks

Source§

fn from_f(f: Self::F) -> Self

Interpret a field element as a commutative algebra element. Read more
Source§

fn from_bool(b: bool) -> Self

Convert from a bool.
Source§

fn from_canonical_u8(n: u8) -> Self

Convert from a canonical u8. Read more
Source§

fn from_canonical_u16(n: u16) -> Self

Convert from a canonical u16. Read more
Source§

fn from_canonical_u32(n: u32) -> Self

Convert from a canonical u32. Read more
Source§

fn from_canonical_u64(n: u64) -> Self

Convert from a canonical u64. Read more
Source§

fn from_canonical_usize(n: usize) -> Self

Convert from a canonical usize. Read more
Source§

fn from_wrapped_u32(n: u32) -> Self

Source§

fn from_wrapped_u64(n: u64) -> Self

Source§

fn zero_vec(len: usize) -> Vec<Self>

Allocates a vector of zero elements of length len. Many operating systems zero pages before assigning them to a userspace process. In that case, our process should not need to write zeros, which would be redundant. However, the compiler may not always recognize this. Read more
Source§

fn double(&self) -> Self

The elementary function double(a) = 2*a. Read more
Source§

fn square(&self) -> Self

The elementary function square(a) = a^2. Read more
Source§

fn cube(&self) -> Self

The elementary function cube(a) = a^3. Read more
Source§

fn exp_u64(&self, power: u64) -> Self

Exponentiation by a u64 power. Read more
Source§

fn exp_const_u64<const POWER: u64>(&self) -> Self

Exponentiation by a constant power. Read more
Source§

fn exp_power_of_2(&self, power_log: usize) -> Self

Compute self^{2^power_log} by repeated squaring.
Source§

fn mul_2exp_u64(&self, exp: u64) -> Self

self * 2^exp
Source§

fn powers(&self) -> Powers<Self>

Construct an iterator which returns powers of self: self^0, self^1, self^2, ....
Source§

fn shifted_powers(&self, start: Self) -> Powers<Self>

Construct an iterator which returns powers of self shifted by start: start, start*self^1, start*self^2, ....
Source§

fn powers_packed<P>(&self) -> Powers<P>
where P: PackedField<Scalar = Self>,

Construct an iterator which returns powers of self packed into PackedField elements. Read more
Source§

fn shifted_powers_packed<P>(&self, start: Self) -> Powers<P>
where P: PackedField<Scalar = Self>,

Construct an iterator which returns powers of self shifted by start and packed into PackedField elements. Read more
Source§

fn dot_product<const N: usize>(u: &[Self; N], v: &[Self; N]) -> Self

Compute the dot product of two vectors.
Source§

impl HasTwoAdicBinomialExtension<2> for Goldilocks

Source§

const EXT_TWO_ADICITY: usize = 33usize

Source§

fn ext_two_adic_generator(bits: usize) -> [Self; 2]

Assumes the multiplicative group size has at least bits powers of two, otherwise the behavior is undefined.
Source§

impl Hash for Goldilocks

Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Mul for Goldilocks

Source§

type Output = Goldilocks

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: Self) -> Self

Performs the * operation. Read more
Source§

impl MulAssign for Goldilocks

Source§

fn mul_assign(&mut self, rhs: Self)

Performs the *= operation. Read more
Source§

impl Neg for Goldilocks

Source§

type Output = Goldilocks

The resulting type after applying the - operator.
Source§

fn neg(self) -> Self::Output

Performs the unary - operation. Read more
Source§

impl Ord for Goldilocks

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for Goldilocks

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for Goldilocks

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

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

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl PrimeField for Goldilocks

Source§

impl PrimeField64 for Goldilocks

Source§

const ORDER_U64: u64 = 18_446_744_069_414_584_321u64

Source§

fn as_canonical_u64(&self) -> u64

Return the representative of value that is less than ORDER_U64.
Source§

fn to_unique_u64(&self) -> u64

Convert a field element to a u64 such that any two field elements are converted to the same u64 if and only if they represent the same value. Read more
Source§

impl Product for Goldilocks

Source§

fn product<I: Iterator<Item = Self>>(iter: I) -> Self

Takes an iterator and generates Self from the elements by multiplying the items.
Source§

impl Serialize for Goldilocks

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 Sub for Goldilocks

Source§

type Output = Goldilocks

The resulting type after applying the - operator.
Source§

fn sub(self, rhs: Self) -> Self

Performs the - operation. Read more
Source§

impl SubAssign for Goldilocks

Source§

fn sub_assign(&mut self, rhs: Self)

Performs the -= operation. Read more
Source§

impl Sum for Goldilocks

Source§

fn sum<I: Iterator<Item = Self>>(iter: I) -> Self

Takes an iterator and generates Self from the elements by “summing up” the items.
Source§

impl TwoAdicField for Goldilocks

Source§

const TWO_ADICITY: usize = 32usize

The number of factors of two in this field’s multiplicative group.
Source§

fn two_adic_generator(bits: usize) -> Self

Returns a generator of the multiplicative group of order 2^bits. Assumes bits <= TWO_ADICITY, otherwise the result is undefined.
Source§

impl Copy for Goldilocks

Source§

impl Eq for Goldilocks

Source§

impl MdsPermutation<Goldilocks, 12> for MdsMatrixGoldilocks

Source§

impl MdsPermutation<Goldilocks, 16> for MdsMatrixGoldilocks

Source§

impl MdsPermutation<Goldilocks, 24> for MdsMatrixGoldilocks

Source§

impl MdsPermutation<Goldilocks, 32> for MdsMatrixGoldilocks

Source§

impl MdsPermutation<Goldilocks, 64> for MdsMatrixGoldilocks

Source§

impl MdsPermutation<Goldilocks, 68> for MdsMatrixGoldilocks

Source§

impl MdsPermutation<Goldilocks, 8> for MdsMatrixGoldilocks

Source§

impl Packable for Goldilocks

Auto Trait Implementations§

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<F> ExtensionField<F> for F
where F: Field,

Source§

type ExtensionPacking = <F as Field>::Packing

Source§

fn is_in_basefield(&self) -> bool

Source§

fn as_base(&self) -> Option<Base>

Source§

fn ext_powers_packed(&self) -> Powers<Self::ExtensionPacking>

Construct an iterator which returns powers of self packed into ExtensionPacking elements. Read more
Source§

impl<FA> FieldExtensionAlgebra<FA> for FA
where FA: FieldAlgebra,

Source§

const D: usize = 1usize

Source§

fn from_base(b: FA) -> FA

Source§

fn from_base_slice(bs: &[FA]) -> FA

Suppose this field extension is represented by the quotient ring B[X]/(f(X)) where B is Base and f is an irreducible polynomial of degree D. This function takes a slice bs of length at exactly D, and constructs the field element \sum_i bs[i] * X^i. Read more
Source§

fn from_base_iter<I>(iter: I) -> FA
where I: Iterator<Item = FA>,

Source§

fn from_base_fn<F>(f: F) -> FA
where F: FnMut(usize) -> FA,

Similar to core:array::from_fn, with the same caveats as from_base_slice.
Source§

fn as_base_slice(&self) -> &[FA]

Suppose this field extension is represented by the quotient ring B[X]/(f(X)) where B is Base and f is an irreducible polynomial of degree D. This function takes a field element \sum_i bs[i] * X^i and returns the coefficients as a slice bs of length at most D containing, from lowest degree to highest. Read more
Source§

fn monomial(exponent: usize) -> Self

Suppose this field extension is represented by the quotient ring B[X]/(f(X)) where B is Base and f is an irreducible polynomial of degree D. This function returns the field element X^exponent if exponent < D and panics otherwise. (The fact that f is not known at the point that this function is defined prevents implementing exponentiation of higher powers since the reduction cannot be performed.) 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<F> PackedField for F
where F: Field,

Source§

impl<F> PackedFieldPow2 for F
where F: Field,

Source§

fn interleave(&self, other: F, block_len: usize) -> (F, F)

Take interpret two vectors as chunks of block_len elements. Unpack and interleave those chunks. This is best seen with an example. If we have: Read more
Source§

impl<T> PackedValue for T
where T: Packable,

Source§

const WIDTH: usize = 1usize

Source§

type Value = T

Source§

fn from_slice(slice: &[<T as PackedValue>::Value]) -> &T

Source§

fn from_slice_mut(slice: &mut [<T as PackedValue>::Value]) -> &mut T

Source§

fn from_fn<Fn>(f: Fn) -> T
where Fn: FnMut(usize) -> <T as PackedValue>::Value,

Similar to core:array::from_fn.
Source§

fn as_slice(&self) -> &[<T as PackedValue>::Value]

Source§

fn as_slice_mut(&mut self) -> &mut [<T as PackedValue>::Value]

Source§

fn pack_slice(buf: &[Self::Value]) -> &[Self]

Source§

fn pack_slice_with_suffix(buf: &[Self::Value]) -> (&[Self], &[Self::Value])

Source§

fn pack_slice_mut(buf: &mut [Self::Value]) -> &mut [Self]

Source§

fn pack_maybe_uninit_slice_mut( buf: &mut [MaybeUninit<Self::Value>], ) -> &mut [MaybeUninit<Self>]

Source§

fn pack_slice_with_suffix_mut( buf: &mut [Self::Value], ) -> (&mut [Self], &mut [Self::Value])

Source§

fn pack_maybe_uninit_slice_with_suffix_mut( buf: &mut [MaybeUninit<Self::Value>], ) -> (&mut [MaybeUninit<Self>], &mut [MaybeUninit<Self::Value>])

Source§

fn unpack_slice(buf: &[Self]) -> &[Self::Value]

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

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

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