pub struct PackedBinomialExtensionField<F: Field, PF: PackedField<Scalar = F>, const D: usize> { /* private fields */ }
Trait Implementations§
Source§impl<F, PF, const D: usize> Add<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Add<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§type Output = PackedBinomialExtensionField<F, PF, D>
type Output = PackedBinomialExtensionField<F, PF, D>
The resulting type after applying the
+
operator.Source§fn add(self, rhs: BinomialExtensionField<F, D>) -> Self
fn add(self, rhs: BinomialExtensionField<F, D>) -> Self
Performs the
+
operation. Read moreSource§impl<F, PF, const D: usize> Add<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Add<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> Add for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Add for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> AddAssign<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> AddAssign<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn add_assign(&mut self, rhs: BinomialExtensionField<F, D>)
fn add_assign(&mut self, rhs: BinomialExtensionField<F, D>)
Performs the
+=
operation. Read moreSource§impl<F, PF, const D: usize> AddAssign<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> AddAssign<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn add_assign(&mut self, rhs: PF)
fn add_assign(&mut self, rhs: PF)
Performs the
+=
operation. Read moreSource§impl<F, PF, const D: usize> AddAssign for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> AddAssign for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn add_assign(&mut self, rhs: Self)
fn add_assign(&mut self, rhs: Self)
Performs the
+=
operation. Read moreSource§impl<F, PF, const D: usize> BasedVectorSpace<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> BasedVectorSpace<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§const DIMENSION: usize = D
const DIMENSION: usize = D
The dimension of the vector space, i.e. the number of elements in
its basis.
Source§fn as_basis_coefficients_slice(&self) -> &[PF]
fn as_basis_coefficients_slice(&self) -> &[PF]
Fixes a basis for the algebra
A
and uses this to
map an element of A
to a slice of DIMENSION
F
elements. Read moreSource§fn from_basis_coefficients_fn<Fn: FnMut(usize) -> PF>(f: Fn) -> Self
fn from_basis_coefficients_fn<Fn: FnMut(usize) -> PF>(f: Fn) -> Self
Fixes a basis for the algebra
A
and uses this to
map DIMENSION
F
elements to an element of A
. Similar
to core:array::from_fn
, the DIMENSION
F
elements are
given by Fn(0), ..., Fn(DIMENSION - 1)
called in that order. Read moreSource§fn from_basis_coefficients_iter<I: ExactSizeIterator<Item = PF>>(
iter: I,
) -> Option<Self>
fn from_basis_coefficients_iter<I: ExactSizeIterator<Item = PF>>( iter: I, ) -> Option<Self>
Fixes a basis for the algebra
A
and uses this to
map DIMENSION
F
elements to an element of A
. Read moreSource§fn flatten_to_base(vec: Vec<Self>) -> Vec<PF>
fn flatten_to_base(vec: Vec<Self>) -> Vec<PF>
Source§fn reconstitute_from_base(vec: Vec<PF>) -> Vec<Self>
fn reconstitute_from_base(vec: Vec<PF>) -> Vec<Self>
Source§impl<F: Clone + Field, PF: Clone + PackedField<Scalar = F>, const D: usize> Clone for PackedBinomialExtensionField<F, PF, D>
impl<F: Clone + Field, PF: Clone + PackedField<Scalar = F>, const D: usize> Clone for PackedBinomialExtensionField<F, PF, D>
Source§fn clone(&self) -> PackedBinomialExtensionField<F, PF, D>
fn clone(&self) -> PackedBinomialExtensionField<F, PF, D>
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<F: Debug + Field, PF: Debug + PackedField<Scalar = F>, const D: usize> Debug for PackedBinomialExtensionField<F, PF, D>
impl<F: Debug + Field, PF: Debug + PackedField<Scalar = F>, const D: usize> Debug for PackedBinomialExtensionField<F, PF, D>
Source§impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> Default for PackedBinomialExtensionField<F, PF, D>
impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> Default for PackedBinomialExtensionField<F, PF, D>
Source§impl<'de, F: Field, PF, const D: usize> Deserialize<'de> for PackedBinomialExtensionField<F, PF, D>where
PF: Deserialize<'de> + PackedField<Scalar = F>,
impl<'de, F: Field, PF, const D: usize> Deserialize<'de> for PackedBinomialExtensionField<F, PF, D>where
PF: Deserialize<'de> + PackedField<Scalar = F>,
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
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: Field, PF: PackedField<Scalar = F>, const D: usize> Distribution<PackedBinomialExtensionField<F, PF, D>> for StandardUniformwhere
Self: Distribution<PF>,
impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> Distribution<PackedBinomialExtensionField<F, PF, D>> for StandardUniformwhere
Self: Distribution<PF>,
Source§fn sample<R: Rng + ?Sized>(
&self,
rng: &mut R,
) -> PackedBinomialExtensionField<F, PF, D>
fn sample<R: Rng + ?Sized>( &self, rng: &mut R, ) -> PackedBinomialExtensionField<F, PF, D>
Generate a random value of
T
, using rng
as the source of randomness.Source§fn sample_iter<R>(self, rng: R) -> Iter<Self, R, T>
fn sample_iter<R>(self, rng: R) -> Iter<Self, R, T>
Create an iterator that generates random values of
T
, using rng
as
the source of randomness. Read moreSource§impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> From<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>
impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> From<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>
Source§fn from(x: BinomialExtensionField<F, D>) -> Self
fn from(x: BinomialExtensionField<F, D>) -> Self
Converts to this type from the input type.
Source§impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> From<PF> for PackedBinomialExtensionField<F, PF, D>
impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> From<PF> for PackedBinomialExtensionField<F, PF, D>
Source§impl<F: Hash + Field, PF: Hash + PackedField<Scalar = F>, const D: usize> Hash for PackedBinomialExtensionField<F, PF, D>
impl<F: Hash + Field, PF: Hash + PackedField<Scalar = F>, const D: usize> Hash for PackedBinomialExtensionField<F, PF, D>
Source§impl<F, PF, const D: usize> Mul<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Mul<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§type Output = PackedBinomialExtensionField<F, PF, D>
type Output = PackedBinomialExtensionField<F, PF, D>
The resulting type after applying the
*
operator.Source§fn mul(self, rhs: BinomialExtensionField<F, D>) -> Self
fn mul(self, rhs: BinomialExtensionField<F, D>) -> Self
Performs the
*
operation. Read moreSource§impl<F, PF, const D: usize> Mul<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Mul<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> Mul for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Mul for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> MulAssign<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> MulAssign<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn mul_assign(&mut self, rhs: BinomialExtensionField<F, D>)
fn mul_assign(&mut self, rhs: BinomialExtensionField<F, D>)
Performs the
*=
operation. Read moreSource§impl<F, PF, const D: usize> MulAssign<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> MulAssign<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn mul_assign(&mut self, rhs: PF)
fn mul_assign(&mut self, rhs: PF)
Performs the
*=
operation. Read moreSource§impl<F, PF, const D: usize> MulAssign for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> MulAssign for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn mul_assign(&mut self, rhs: Self)
fn mul_assign(&mut self, rhs: Self)
Performs the
*=
operation. Read moreSource§impl<F, PF, const D: usize> Neg for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Neg for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F: Ord + Field, PF: Ord + PackedField<Scalar = F>, const D: usize> Ord for PackedBinomialExtensionField<F, PF, D>
impl<F: Ord + Field, PF: Ord + PackedField<Scalar = F>, const D: usize> Ord for PackedBinomialExtensionField<F, PF, D>
Source§fn cmp(&self, other: &PackedBinomialExtensionField<F, PF, D>) -> Ordering
fn cmp(&self, other: &PackedBinomialExtensionField<F, PF, D>) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
Source§impl<F, const D: usize> PackedFieldExtension<F, BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, F::Packing, D>where
F: BinomiallyExtendable<D>,
impl<F, const D: usize> PackedFieldExtension<F, BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, F::Packing, D>where
F: BinomiallyExtendable<D>,
Source§fn from_ext_slice(ext_slice: &[BinomialExtensionField<F, D>]) -> Self
fn from_ext_slice(ext_slice: &[BinomialExtensionField<F, D>]) -> Self
Given a slice of extension field
EF
elements of length W
,
convert into the array [[F; D]; W]
transpose to
[[F; W]; D]
and then pack to get [PF; D]
.Source§fn to_ext_iter(
iter: impl IntoIterator<Item = Self>,
) -> impl Iterator<Item = BinomialExtensionField<F, D>>
fn to_ext_iter( iter: impl IntoIterator<Item = Self>, ) -> impl Iterator<Item = BinomialExtensionField<F, D>>
Given a iterator of packed extension field elements, convert to an iterator of
extension field elements. Read more
Source§fn packed_ext_powers(base: BinomialExtensionField<F, D>) -> Powers<Self> ⓘ
fn packed_ext_powers(base: BinomialExtensionField<F, D>) -> Powers<Self> ⓘ
Similar to
packed_powers
, construct an iterator which returns
powers of base
packed into PackedFieldExtension
elements.Source§impl<F: PartialEq + Field, PF: PartialEq + PackedField<Scalar = F>, const D: usize> PartialEq for PackedBinomialExtensionField<F, PF, D>
impl<F: PartialEq + Field, PF: PartialEq + PackedField<Scalar = F>, const D: usize> PartialEq for PackedBinomialExtensionField<F, PF, D>
Source§fn eq(&self, other: &PackedBinomialExtensionField<F, PF, D>) -> bool
fn eq(&self, other: &PackedBinomialExtensionField<F, PF, D>) -> bool
Tests for
self
and other
values to be equal, and is used by ==
.Source§impl<F: PartialOrd + Field, PF: PartialOrd + PackedField<Scalar = F>, const D: usize> PartialOrd for PackedBinomialExtensionField<F, PF, D>
impl<F: PartialOrd + Field, PF: PartialOrd + PackedField<Scalar = F>, const D: usize> PartialOrd for PackedBinomialExtensionField<F, PF, D>
Source§impl<F, PF, const D: usize> PrimeCharacteristicRing for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> PrimeCharacteristicRing for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§type PrimeSubfield = <PF as PrimeCharacteristicRing>::PrimeSubfield
type PrimeSubfield = <PF as PrimeCharacteristicRing>::PrimeSubfield
The field
ℤ/p
where the characteristic of this ring is p.Source§fn from_prime_subfield(val: Self::PrimeSubfield) -> Self
fn from_prime_subfield(val: Self::PrimeSubfield) -> Self
Source§fn zero_vec(len: usize) -> Vec<Self>
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 moreSource§fn from_usize(int: usize) -> Self
fn from_usize(int: usize) -> Self
Source§fn from_isize(int: isize) -> Self
fn from_isize(int: isize) -> Self
Source§fn xor(&self, y: &Self) -> Self
fn xor(&self, y: &Self) -> Self
Computes the arithmetic generalization of boolean
xor
. Read moreSource§fn xor3(&self, y: &Self, z: &Self) -> Self
fn xor3(&self, y: &Self, z: &Self) -> Self
Computes the arithmetic generalization of a triple
xor
. Read moreSource§fn bool_check(&self) -> Self
fn bool_check(&self) -> Self
The vanishing polynomial for boolean values:
x * (1 - x)
. Read moreSource§fn exp_const_u64<const POWER: u64>(&self) -> Self
fn exp_const_u64<const POWER: u64>(&self) -> Self
Exponentiation by a small constant power. Read more
Source§fn exp_power_of_2(&self, power_log: usize) -> Self
fn exp_power_of_2(&self, power_log: usize) -> Self
The elementary function
exp_power_of_2(a, power_log) = a^{2^power_log}
. Read moreSource§fn mul_2exp_u64(&self, exp: u64) -> Self
fn mul_2exp_u64(&self, exp: u64) -> Self
The elementary function
mul_2exp_u64(a, exp) = a * 2^{exp}
. Read moreSource§fn powers(&self) -> Powers<Self> ⓘ
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> ⓘ
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§impl<F, PF, const D: usize> Product for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Product for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F: Field, PF, const D: usize> Serialize for PackedBinomialExtensionField<F, PF, D>where
PF: Serialize + PackedField<Scalar = F>,
impl<F: Field, PF, const D: usize> Serialize for PackedBinomialExtensionField<F, PF, D>where
PF: Serialize + PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> Sub<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Sub<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§type Output = PackedBinomialExtensionField<F, PF, D>
type Output = PackedBinomialExtensionField<F, PF, D>
The resulting type after applying the
-
operator.Source§fn sub(self, rhs: BinomialExtensionField<F, D>) -> Self
fn sub(self, rhs: BinomialExtensionField<F, D>) -> Self
Performs the
-
operation. Read moreSource§impl<F, PF, const D: usize> Sub<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Sub<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> Sub for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Sub for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§impl<F, PF, const D: usize> SubAssign<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> SubAssign<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn sub_assign(&mut self, rhs: BinomialExtensionField<F, D>)
fn sub_assign(&mut self, rhs: BinomialExtensionField<F, D>)
Performs the
-=
operation. Read moreSource§impl<F, PF, const D: usize> SubAssign<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> SubAssign<PF> for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn sub_assign(&mut self, rhs: PF)
fn sub_assign(&mut self, rhs: PF)
Performs the
-=
operation. Read moreSource§impl<F, PF, const D: usize> SubAssign for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> SubAssign for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
Source§fn sub_assign(&mut self, rhs: Self)
fn sub_assign(&mut self, rhs: Self)
Performs the
-=
operation. Read moreSource§impl<F, PF, const D: usize> Sum for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F, PF, const D: usize> Sum for PackedBinomialExtensionField<F, PF, D>where
F: BinomiallyExtendable<D>,
PF: PackedField<Scalar = F>,
impl<F: BinomiallyExtendable<D>, PF: PackedField<Scalar = F>, const D: usize> Algebra<BinomialExtensionField<F, D>> for PackedBinomialExtensionField<F, PF, D>
impl<F: BinomiallyExtendable<D>, PF: PackedField<Scalar = F>, const D: usize> Algebra<PF> for PackedBinomialExtensionField<F, PF, D>
impl<F: Copy + Field, PF: Copy + PackedField<Scalar = F>, const D: usize> Copy for PackedBinomialExtensionField<F, PF, D>
impl<F: Eq + Field, PF: Eq + PackedField<Scalar = F>, const D: usize> Eq for PackedBinomialExtensionField<F, PF, D>
impl<F: Field, PF: PackedField<Scalar = F>, const D: usize> StructuralPartialEq for PackedBinomialExtensionField<F, PF, D>
Auto Trait Implementations§
impl<F, PF, const D: usize> Freeze for PackedBinomialExtensionField<F, PF, D>where
PF: Freeze,
impl<F, PF, const D: usize> RefUnwindSafe for PackedBinomialExtensionField<F, PF, D>where
PF: RefUnwindSafe,
impl<F, PF, const D: usize> Send for PackedBinomialExtensionField<F, PF, D>
impl<F, PF, const D: usize> Sync for PackedBinomialExtensionField<F, PF, D>
impl<F, PF, const D: usize> Unpin for PackedBinomialExtensionField<F, PF, D>where
PF: Unpin,
impl<F, PF, const D: usize> UnwindSafe for PackedBinomialExtensionField<F, PF, D>where
PF: UnwindSafe,
Blanket Implementations§
Source§impl<F> BasedVectorSpace<F> for Fwhere
F: PrimeCharacteristicRing,
impl<F> BasedVectorSpace<F> for Fwhere
F: PrimeCharacteristicRing,
Source§const DIMENSION: usize = 1usize
const DIMENSION: usize = 1usize
The dimension of the vector space, i.e. the number of elements in
its basis.
Source§fn as_basis_coefficients_slice(&self) -> &[F]
fn as_basis_coefficients_slice(&self) -> &[F]
Fixes a basis for the algebra
A
and uses this to
map an element of A
to a slice of DIMENSION
F
elements. Read moreSource§fn from_basis_coefficients_fn<Fn>(f: Fn) -> F
fn from_basis_coefficients_fn<Fn>(f: Fn) -> F
Fixes a basis for the algebra
A
and uses this to
map DIMENSION
F
elements to an element of A
. Similar
to core:array::from_fn
, the DIMENSION
F
elements are
given by Fn(0), ..., Fn(DIMENSION - 1)
called in that order. Read moreSource§fn from_basis_coefficients_iter<I>(iter: I) -> Option<F>where
I: ExactSizeIterator<Item = F>,
fn from_basis_coefficients_iter<I>(iter: I) -> Option<F>where
I: ExactSizeIterator<Item = F>,
Fixes a basis for the algebra
A
and uses this to
map DIMENSION
F
elements to an element of A
. Read moreSource§fn flatten_to_base(vec: Vec<F>) -> Vec<F>
fn flatten_to_base(vec: Vec<F>) -> Vec<F>
Source§fn reconstitute_from_base(vec: Vec<F>) -> Vec<F>
fn reconstitute_from_base(vec: Vec<F>) -> Vec<F>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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