ark_test_curves::quadratic_extension

Struct QuadExtField

Source
pub struct QuadExtField<P>
where P: QuadExtConfig,
{ pub c0: <P as QuadExtConfig>::BaseField, pub c1: <P as QuadExtConfig>::BaseField, }
Expand description

An element of a quadratic extension field F_p[X]/(X^2 - P::NONRESIDUE) is represented as c0 + c1 * X, for c0, c1 in P::BaseField.

Fields§

§c0: <P as QuadExtConfig>::BaseField

Coefficient c0 in the representation of the field element c = c0 + c1 * X

§c1: <P as QuadExtConfig>::BaseField

Coefficient c1 in the representation of the field element c = c0 + c1 * X

Implementations§

Source§

impl<P> QuadExtField<Fp2ConfigWrapper<P>>
where P: Fp2Config,

Source

pub fn mul_assign_by_fp(&mut self, other: &<P as Fp2Config>::Fp)

In-place multiply both coefficients c0 and c1 of self by an element from Fp.

§Examples
let c0: Fp = Fp::rand(&mut test_rng());
let c1: Fp = Fp::rand(&mut test_rng());
let mut ext_element: Fp2 = Fp2::new(c0, c1);

let base_field_element: Fp = Fp::rand(&mut test_rng());
ext_element.mul_assign_by_fp(&base_field_element);

assert_eq!(ext_element.c0, c0 * base_field_element);
assert_eq!(ext_element.c1, c1 * base_field_element);
Source§

impl<P> QuadExtField<Fp4ConfigWrapper<P>>
where P: Fp4Config,

Source

pub fn mul_by_fp( &mut self, element: &<<P as Fp4Config>::Fp2Config as Fp2Config>::Fp, )

Source

pub fn mul_by_fp2( &mut self, element: &QuadExtField<Fp2ConfigWrapper<<P as Fp4Config>::Fp2Config>>, )

Source§

impl<P> QuadExtField<Fp6ConfigWrapper<P>>
where P: Fp6Config,

Source

pub fn mul_by_034( &mut self, c0: &<<P as Fp6Config>::Fp3Config as Fp3Config>::Fp, c3: &<<P as Fp6Config>::Fp3Config as Fp3Config>::Fp, c4: &<<P as Fp6Config>::Fp3Config as Fp3Config>::Fp, )

Source

pub fn mul_by_014( &mut self, c0: &<<P as Fp6Config>::Fp3Config as Fp3Config>::Fp, c1: &<<P as Fp6Config>::Fp3Config as Fp3Config>::Fp, c4: &<<P as Fp6Config>::Fp3Config as Fp3Config>::Fp, )

Source§

impl<P> QuadExtField<Fp12ConfigWrapper<P>>
where P: Fp12Config,

Source§

impl<P> QuadExtField<P>
where P: QuadExtConfig,

Source

pub const fn new( c0: <P as QuadExtConfig>::BaseField, c1: <P as QuadExtConfig>::BaseField, ) -> QuadExtField<P>

Create a new field element from coefficients c0 and c1, so that the result is of the form c0 + c1 * X.

§Examples
let c0: Fp = Fp::rand(&mut test_rng());
let c1: Fp = Fp::rand(&mut test_rng());
// `Fp2` a degree-2 extension over `Fp`.
let c: Fp2 = Fp2::new(c0, c1);
Source

pub fn conjugate_in_place(&mut self) -> &mut QuadExtField<P>

This is only to be used when the element is known to be in the cyclotomic subgroup.

Source

pub fn norm(&self) -> <P as QuadExtConfig>::BaseField

Norm of QuadExtField over P::BaseField:Norm(a) = a * a.conjugate(). This simplifies to: Norm(a) = a.x^2 - P::NON_RESIDUE * a.y^2. This is alternatively expressed as Norm(a) = a^(1 + p).

§Examples
let c: Fp2 = Fp2::rand(&mut test_rng());
let norm = c.norm();
// We now compute the norm using the `a * a.conjugate()` approach.
// A Frobenius map sends an element of `Fp2` to one of its p_th powers:
// `a.frobenius_map_in_place(1) -> a^p` and `a^p` is also `a`'s Galois conjugate.
let mut c_conjugate = c;
c_conjugate.frobenius_map_in_place(1);
let norm2 = c * c_conjugate;
// Computing the norm of an `Fp2` element should result in an element
// in BaseField `Fp`, i.e. `c1 == 0`
assert!(norm2.c1.is_zero());
assert_eq!(norm, norm2.c0);
Source

pub fn mul_assign_by_basefield( &mut self, element: &<P as QuadExtConfig>::BaseField, )

In-place multiply both coefficients c0 & c1 of the quadratic extension field by an element from the base field.

Trait Implementations§

Source§

impl<'a, 'b, P> Add<&'a QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the + operator.
Source§

fn add(self, other: &'a QuadExtField<P>) -> QuadExtField<P>

Performs the + operation. Read more
Source§

impl<'a, P> Add<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the + operator.
Source§

fn add(self, other: &QuadExtField<P>) -> QuadExtField<P>

Performs the + operation. Read more
Source§

impl<'a, 'b, P> Add<&'a mut QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the + operator.
Source§

fn add(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the + operation. Read more
Source§

impl<'a, P> Add<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the + operator.
Source§

fn add(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the + operation. Read more
Source§

impl<'b, P> Add<QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the + operator.
Source§

fn add(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the + operation. Read more
Source§

impl<P> Add for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the + operator.
Source§

fn add(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the + operation. Read more
Source§

impl<'a, P> AddAssign<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn add_assign(&mut self, other: &QuadExtField<P>)

Performs the += operation. Read more
Source§

impl<'a, P> AddAssign<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn add_assign(&mut self, other: &'a mut QuadExtField<P>)

Performs the += operation. Read more
Source§

impl<P> AddAssign for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn add_assign(&mut self, other: QuadExtField<P>)

Performs the += operation. Read more
Source§

impl<P> AdditiveGroup for QuadExtField<P>
where P: QuadExtConfig,

Source§

const ZERO: QuadExtField<P> = _

The additive identity of the field.
Source§

type Scalar = QuadExtField<P>

Source§

fn double(&self) -> QuadExtField<P>

Doubles self.
Source§

fn double_in_place(&mut self) -> &mut QuadExtField<P>

Doubles self in place.
Source§

fn neg_in_place(&mut self) -> &mut QuadExtField<P>

Negates self in place.
Source§

impl<P> CanonicalDeserialize for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn deserialize_with_mode<R>( reader: R, compress: Compress, validate: Validate, ) -> Result<QuadExtField<P>, SerializationError>
where R: Read,

The general deserialize method that takes in customization flags.
Source§

fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>
where R: Read,

Source§

fn deserialize_compressed_unchecked<R>( reader: R, ) -> Result<Self, SerializationError>
where R: Read,

Source§

fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>
where R: Read,

Source§

fn deserialize_uncompressed_unchecked<R>( reader: R, ) -> Result<Self, SerializationError>
where R: Read,

Source§

impl<P> CanonicalDeserializeWithFlags for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn deserialize_with_flags<R, F>( reader: R, ) -> Result<(QuadExtField<P>, F), SerializationError>
where R: Read, F: Flags,

Reads Self and Flags from reader. Returns empty flags by default.
Source§

impl<P> CanonicalSerialize for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn serialize_with_mode<W>( &self, writer: W, _compress: Compress, ) -> Result<(), SerializationError>
where W: Write,

The general serialize method that takes in customization flags.
Source§

fn serialized_size(&self, _compress: Compress) -> usize

Source§

fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>
where W: Write,

Source§

fn compressed_size(&self) -> usize

Source§

fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>
where W: Write,

Source§

fn uncompressed_size(&self) -> usize

Source§

impl<P> CanonicalSerializeWithFlags for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn serialize_with_flags<W, F>( &self, writer: W, flags: F, ) -> Result<(), SerializationError>
where W: Write, F: Flags,

Serializes self and flags into writer.
Source§

fn serialized_size_with_flags<F>(&self) -> usize
where F: Flags,

Serializes self and flags into writer.
Source§

impl<P> Clone for QuadExtField<P>

Source§

fn clone(&self) -> QuadExtField<P>

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<P> CyclotomicMultSubgroup for QuadExtField<Fp12ConfigWrapper<P>>
where P: Fp12Config,

Source§

const INVERSE_IS_FAST: bool = true

Is the inverse fast to compute? For example, in quadratic extensions, the inverse can be computed at the cost of negating one coordinate, which is much faster than standard inversion. By default this is false, but should be set to true for quadratic extensions.
Source§

fn cyclotomic_inverse_in_place( &mut self, ) -> Option<&mut QuadExtField<Fp12ConfigWrapper<P>>>

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_square_in_place( &mut self, ) -> &mut QuadExtField<Fp12ConfigWrapper<P>>

Square self in place. By default this is computed using Field::square_in_place, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

fn cyclotomic_square(&self) -> Self

Compute a square in the cyclotomic subgroup. By default this is computed using Field::square, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

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

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_exp(&self, e: impl AsRef<[u64]>) -> Self

Compute a cyclotomic exponentiation of self with respect to e. Read more
Source§

fn cyclotomic_exp_in_place(&mut self, e: impl AsRef<[u64]>)

Set self to be the result of exponentiating self by e, using efficient cyclotomic algorithms. Read more
Source§

impl<P> CyclotomicMultSubgroup for QuadExtField<Fp2ConfigWrapper<P>>
where P: Fp2Config,

Source§

const INVERSE_IS_FAST: bool = true

Is the inverse fast to compute? For example, in quadratic extensions, the inverse can be computed at the cost of negating one coordinate, which is much faster than standard inversion. By default this is false, but should be set to true for quadratic extensions.
Source§

fn cyclotomic_inverse_in_place( &mut self, ) -> Option<&mut QuadExtField<Fp2ConfigWrapper<P>>>

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_square(&self) -> Self

Compute a square in the cyclotomic subgroup. By default this is computed using Field::square, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

fn cyclotomic_square_in_place(&mut self) -> &mut Self

Square self in place. By default this is computed using Field::square_in_place, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

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

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_exp(&self, e: impl AsRef<[u64]>) -> Self

Compute a cyclotomic exponentiation of self with respect to e. Read more
Source§

fn cyclotomic_exp_in_place(&mut self, e: impl AsRef<[u64]>)

Set self to be the result of exponentiating self by e, using efficient cyclotomic algorithms. Read more
Source§

impl<P> CyclotomicMultSubgroup for QuadExtField<Fp4ConfigWrapper<P>>
where P: Fp4Config,

Source§

const INVERSE_IS_FAST: bool = true

Is the inverse fast to compute? For example, in quadratic extensions, the inverse can be computed at the cost of negating one coordinate, which is much faster than standard inversion. By default this is false, but should be set to true for quadratic extensions.
Source§

fn cyclotomic_inverse_in_place( &mut self, ) -> Option<&mut QuadExtField<Fp4ConfigWrapper<P>>>

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_square(&self) -> Self

Compute a square in the cyclotomic subgroup. By default this is computed using Field::square, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

fn cyclotomic_square_in_place(&mut self) -> &mut Self

Square self in place. By default this is computed using Field::square_in_place, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

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

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_exp(&self, e: impl AsRef<[u64]>) -> Self

Compute a cyclotomic exponentiation of self with respect to e. Read more
Source§

fn cyclotomic_exp_in_place(&mut self, e: impl AsRef<[u64]>)

Set self to be the result of exponentiating self by e, using efficient cyclotomic algorithms. Read more
Source§

impl<P> CyclotomicMultSubgroup for QuadExtField<Fp6ConfigWrapper<P>>
where P: Fp6Config,

Source§

const INVERSE_IS_FAST: bool = true

Is the inverse fast to compute? For example, in quadratic extensions, the inverse can be computed at the cost of negating one coordinate, which is much faster than standard inversion. By default this is false, but should be set to true for quadratic extensions.
Source§

fn cyclotomic_inverse_in_place( &mut self, ) -> Option<&mut QuadExtField<Fp6ConfigWrapper<P>>>

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_square(&self) -> Self

Compute a square in the cyclotomic subgroup. By default this is computed using Field::square, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

fn cyclotomic_square_in_place(&mut self) -> &mut Self

Square self in place. By default this is computed using Field::square_in_place, but for degree 12 extensions, this can be computed faster than normal squaring. Read more
Source§

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

Compute the inverse of self. See Self::INVERSE_IS_FAST for details. Returns None if self.is_zero(), and Some otherwise. Read more
Source§

fn cyclotomic_exp(&self, e: impl AsRef<[u64]>) -> Self

Compute a cyclotomic exponentiation of self with respect to e. Read more
Source§

fn cyclotomic_exp_in_place(&mut self, e: impl AsRef<[u64]>)

Set self to be the result of exponentiating self by e, using efficient cyclotomic algorithms. Read more
Source§

impl<P> Debug for QuadExtField<P>

Source§

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

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

impl<P> Default for QuadExtField<P>

Source§

fn default() -> QuadExtField<P>

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

impl<P> Display for QuadExtField<P>
where P: QuadExtConfig,

Source§

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

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

impl<'a, 'b, P> Div<&'a QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the / operator.
Source§

fn div(self, other: &'a QuadExtField<P>) -> QuadExtField<P>

Performs the / operation. Read more
Source§

impl<'a, P> Div<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the / operator.
Source§

fn div(self, other: &QuadExtField<P>) -> QuadExtField<P>

Performs the / operation. Read more
Source§

impl<'a, 'b, P> Div<&'a mut QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the / operator.
Source§

fn div(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the / operation. Read more
Source§

impl<'a, P> Div<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the / operator.
Source§

fn div(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the / operation. Read more
Source§

impl<'b, P> Div<QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the / operator.
Source§

fn div(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the / operation. Read more
Source§

impl<P> Div for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the / operator.
Source§

fn div(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the / operation. Read more
Source§

impl<'a, P> DivAssign<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn div_assign(&mut self, other: &QuadExtField<P>)

Performs the /= operation. Read more
Source§

impl<'a, P> DivAssign<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn div_assign(&mut self, other: &'a mut QuadExtField<P>)

Performs the /= operation. Read more
Source§

impl<P> DivAssign for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn div_assign(&mut self, other: QuadExtField<P>)

Performs the /= operation. Read more
Source§

impl<P> FftField for QuadExtField<P>

Source§

const GENERATOR: QuadExtField<P> = _

The generator of the multiplicative group of the field
Source§

const TWO_ADICITY: u32 = <P::BaseField>::TWO_ADICITY

Let N be the size of the multiplicative group defined by the field. Then TWO_ADICITY is the two-adicity of N, i.e. the integer s such that N = 2^s * t for some odd integer t.
Source§

const TWO_ADIC_ROOT_OF_UNITY: QuadExtField<P> = _

2^s root of unity computed by GENERATOR^t
Source§

const SMALL_SUBGROUP_BASE: Option<u32> = <P::BaseField>::SMALL_SUBGROUP_BASE

An integer b such that there exists a multiplicative subgroup of size b^k for some integer k.
Source§

const SMALL_SUBGROUP_BASE_ADICITY: Option<u32> = <P::BaseField>::SMALL_SUBGROUP_BASE_ADICITY

The integer k such that there exists a multiplicative subgroup of size Self::SMALL_SUBGROUP_BASE^k.
Source§

const LARGE_SUBGROUP_ROOT_OF_UNITY: Option<QuadExtField<P>> = _

GENERATOR^((MODULUS-1) / (2^s * SMALL_SUBGROUP_BASE^SMALL_SUBGROUP_BASE_ADICITY)) Used for mixed-radix FFT.
Source§

fn get_root_of_unity(n: u64) -> Option<Self>

Returns the root of unity of order n, if one exists. If no small multiplicative subgroup is defined, this is the 2-adic root of unity of order n (for n a power of 2). If a small multiplicative subgroup is defined, this is the root of unity of order n for the larger subgroup generated by FftConfig::LARGE_SUBGROUP_ROOT_OF_UNITY (for n = 2^i * FftConfig::SMALL_SUBGROUP_BASE^j for some i, j).
Source§

impl<P> Field for QuadExtField<P>
where P: QuadExtConfig,

Source§

const SQRT_PRECOMP: Option<SqrtPrecomputation<QuadExtField<P>>> = None

Determines the algorithm for computing square roots.
Source§

const ONE: QuadExtField<P> = _

The multiplicative identity of the field.
Source§

type BasePrimeField = <P as QuadExtConfig>::BasePrimeField

Source§

fn extension_degree() -> u64

Returns the extension degree of this field with respect to Self::BasePrimeField.
Source§

fn from_base_prime_field( elem: <QuadExtField<P> as Field>::BasePrimeField, ) -> QuadExtField<P>

Constructs a field element from a single base prime field elements. Read more
Source§

fn to_base_prime_field_elements( &self, ) -> impl Iterator<Item = <QuadExtField<P> as Field>::BasePrimeField>

Source§

fn from_base_prime_field_elems( elems: impl IntoIterator<Item = <QuadExtField<P> as Field>::BasePrimeField>, ) -> Option<QuadExtField<P>>

Convert a slice of base prime field elements into a field element. If the slice length != Self::extension_degree(), must return None.
Source§

fn square(&self) -> QuadExtField<P>

Returns self * self.
Source§

fn from_random_bytes_with_flags<F>(bytes: &[u8]) -> Option<(QuadExtField<P>, F)>
where F: Flags,

Attempt to deserialize a field element, splitting the bitflags metadata according to F specification. Returns None if the deserialization fails. Read more
Source§

fn from_random_bytes(bytes: &[u8]) -> Option<QuadExtField<P>>

Attempt to deserialize a field element. Returns None if the deserialization fails. Read more
Source§

fn square_in_place(&mut self) -> &mut QuadExtField<P>

Squares self in place.
Source§

fn inverse(&self) -> Option<QuadExtField<P>>

Computes the multiplicative inverse of self if self is nonzero.
Source§

fn inverse_in_place(&mut self) -> Option<&mut QuadExtField<P>>

If self.inverse().is_none(), this just returns None. Otherwise, it sets self to self.inverse().unwrap().
Source§

fn frobenius_map_in_place(&mut self, power: usize)

Sets self to self^s, where s = Self::BasePrimeField::MODULUS^power. This is also called the Frobenius automorphism.
Source§

fn legendre(&self) -> LegendreSymbol

Returns a LegendreSymbol, which indicates whether this field element is 1 : a quadratic residue 0 : equal to 0 -1 : a quadratic non-residue
Source§

fn sqrt(&self) -> Option<QuadExtField<P>>

Returns the square root of self, if it exists.
Source§

fn sqrt_in_place(&mut self) -> Option<&mut QuadExtField<P>>

Sets self to be the square root of self, if it exists.
Source§

fn mul_by_base_prime_field( &self, elem: &<QuadExtField<P> as Field>::BasePrimeField, ) -> QuadExtField<P>

Source§

fn characteristic() -> &'static [u64]

Returns the characteristic of the field, in little-endian representation.
Source§

fn sum_of_products<const T: usize>(a: &[Self; T], b: &[Self; T]) -> Self

Returns sum([a_i * b_i]).
Source§

fn frobenius_map(&self, power: usize) -> Self

Returns self^s, where s = Self::BasePrimeField::MODULUS^power. This is also called the Frobenius automorphism.
Source§

fn pow<S>(&self, exp: S) -> Self
where S: AsRef<[u64]>,

Returns self^exp, where exp is an integer represented with u64 limbs, least significant limb first.
Source§

fn pow_with_table<S>(powers_of_2: &[Self], exp: S) -> Option<Self>
where S: AsRef<[u64]>,

Exponentiates a field element f by a number represented with u64 limbs, using a precomputed table containing as many powers of 2 of f as the 1 + the floor of log2 of the exponent exp, starting from the 1st power. That is, powers_of_2 should equal &[p, p^2, p^4, ..., p^(2^n)] when exp has at most n bits. Read more
Source§

impl<P> From<bool> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(other: bool) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<i128> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(val: i128) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<i16> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(val: i16) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<i32> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(val: i32) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<i64> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(val: i64) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<i8> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(val: i8) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<u128> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(other: u128) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<u16> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(other: u16) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<u32> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(other: u32) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<u64> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(other: u64) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> From<u8> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn from(other: u8) -> QuadExtField<P>

Converts to this type from the input type.
Source§

impl<P> Hash for QuadExtField<P>

Source§

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

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<'a, 'b, P> Mul<&'a QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the * operator.
Source§

fn mul(self, other: &'a QuadExtField<P>) -> QuadExtField<P>

Performs the * operation. Read more
Source§

impl<'a, P> Mul<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the * operator.
Source§

fn mul(self, other: &QuadExtField<P>) -> QuadExtField<P>

Performs the * operation. Read more
Source§

impl<'a, 'b, P> Mul<&'a mut QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the * operator.
Source§

fn mul(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the * operation. Read more
Source§

impl<'a, P> Mul<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the * operator.
Source§

fn mul(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the * operation. Read more
Source§

impl<'b, P> Mul<QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the * operator.
Source§

fn mul(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the * operation. Read more
Source§

impl<P> Mul for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the * operator.
Source§

fn mul(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the * operation. Read more
Source§

impl<'a, P> MulAssign<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn mul_assign(&mut self, other: &QuadExtField<P>)

Performs the *= operation. Read more
Source§

impl<'a, P> MulAssign<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn mul_assign(&mut self, other: &'a mut QuadExtField<P>)

Performs the *= operation. Read more
Source§

impl<P> MulAssign for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn mul_assign(&mut self, other: QuadExtField<P>)

Performs the *= operation. Read more
Source§

impl<P> Neg for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn neg(self) -> QuadExtField<P>

Performs the unary - operation. Read more
Source§

impl<P> One for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn one() -> QuadExtField<P>

Returns the multiplicative identity element of Self, 1. Read more
Source§

fn is_one(&self) -> bool

Returns true if self is equal to the multiplicative identity. Read more
Source§

fn set_one(&mut self)

Sets self to the multiplicative identity element of Self, 1.
Source§

impl<P> Ord for QuadExtField<P>
where P: QuadExtConfig,

QuadExtField elements are ordered lexicographically.

Source§

fn cmp(&self, other: &QuadExtField<P>) -> 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<P> PartialEq for QuadExtField<P>

Source§

fn eq(&self, other: &QuadExtField<P>) -> 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<P> PartialOrd for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn partial_cmp(&self, other: &QuadExtField<P>) -> 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<'a, P> Product<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn product<I>(iter: I) -> QuadExtField<P>
where I: Iterator<Item = &'a QuadExtField<P>>,

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

impl<P> Product for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn product<I>(iter: I) -> QuadExtField<P>
where I: Iterator<Item = QuadExtField<P>>,

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

impl<'a, 'b, P> Sub<&'a QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn sub(self, other: &'a QuadExtField<P>) -> QuadExtField<P>

Performs the - operation. Read more
Source§

impl<'a, P> Sub<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn sub(self, other: &QuadExtField<P>) -> QuadExtField<P>

Performs the - operation. Read more
Source§

impl<'a, 'b, P> Sub<&'a mut QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn sub(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the - operation. Read more
Source§

impl<'a, P> Sub<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn sub(self, other: &'a mut QuadExtField<P>) -> QuadExtField<P>

Performs the - operation. Read more
Source§

impl<'b, P> Sub<QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn sub(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the - operation. Read more
Source§

impl<P> Sub for QuadExtField<P>
where P: QuadExtConfig,

Source§

type Output = QuadExtField<P>

The resulting type after applying the - operator.
Source§

fn sub(self, other: QuadExtField<P>) -> QuadExtField<P>

Performs the - operation. Read more
Source§

impl<'a, P> SubAssign<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn sub_assign(&mut self, other: &QuadExtField<P>)

Performs the -= operation. Read more
Source§

impl<'a, P> SubAssign<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn sub_assign(&mut self, other: &'a mut QuadExtField<P>)

Performs the -= operation. Read more
Source§

impl<P> SubAssign for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn sub_assign(&mut self, other: QuadExtField<P>)

Performs the -= operation. Read more
Source§

impl<'a, P> Sum<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn sum<I>(iter: I) -> QuadExtField<P>
where I: Iterator<Item = &'a QuadExtField<P>>,

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

impl<P> Sum for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn sum<I>(iter: I) -> QuadExtField<P>
where I: Iterator<Item = QuadExtField<P>>,

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

impl<P> ToConstraintField<<P as QuadExtConfig>::BasePrimeField> for QuadExtField<P>

Source§

impl<P> Valid for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn check(&self) -> Result<(), SerializationError>

Source§

fn batch_check<'a>( batch: impl Iterator<Item = &'a Self> + Send, ) -> Result<(), SerializationError>
where Self: 'a,

Source§

impl<P> Zero for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn zero() -> QuadExtField<P>

Returns the additive identity element of Self, 0. Read more
Source§

fn is_zero(&self) -> bool

Returns true if self is equal to the additive identity.
Source§

fn set_zero(&mut self)

Sets self to the additive identity element of Self, 0.
Source§

impl<P> Zeroize for QuadExtField<P>
where P: QuadExtConfig,

Source§

fn zeroize(&mut self)

Zero out this object from memory using Rust intrinsics which ensure the zeroization operation is not “optimized away” by the compiler.
Source§

impl<P> Copy for QuadExtField<P>

Source§

impl<P> Eq for QuadExtField<P>

Auto Trait Implementations§

§

impl<P> Freeze for QuadExtField<P>

§

impl<P> RefUnwindSafe for QuadExtField<P>

§

impl<P> Send for QuadExtField<P>

§

impl<P> Sync for QuadExtField<P>

§

impl<P> Unpin for QuadExtField<P>
where <P as QuadExtConfig>::BaseField: Unpin,

§

impl<P> UnwindSafe for QuadExtField<P>

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

Source§

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

Source§

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. 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> 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> Same for T

Source§

type Output = T

Should always be Self
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§

default 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<T> UniformRand for T

Source§

fn rand<R>(rng: &mut R) -> T
where R: Rng + ?Sized,

Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T, F> DomainCoeff<F> for T
where F: FftField, T: Copy + Send + Sync + Add<Output = T> + Sub<Output = T> + AddAssign + SubAssign + Zero + MulAssign<F> + Debug + PartialEq,