pub struct U256Field;Expand description
Although U256 is technically not a field, we utilize FieldParameters here for compatibility.
This approach is specifically for the FieldOps multiplication operation, which employs these
parameters solely as a modulus, rather than enforcing the requirement of being a proper field.
Trait Implementations§
source§impl<'de> Deserialize<'de> for U256Field
impl<'de> Deserialize<'de> for U256Field
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 FieldParameters for U256Field
impl FieldParameters for U256Field
source§const MODULUS: &'static [u8] = _
const MODULUS: &'static [u8] = _
The modulus of the field. It is represented as a little-endian array of 33 bytes.
source§const WITNESS_OFFSET: usize = 16_384usize
const WITNESS_OFFSET: usize = 16_384usize
A rough witness-offset estimate given the size of the limbs and the size of the field.
const NB_BITS_PER_LIMB: usize = 8usize
const NB_LIMBS: usize = <Self::Limbs>::USIZE
const NB_WITNESS_LIMBS: usize = <Self::Witness>::USIZE
fn nb_bits() -> usize
fn modulus_field_iter<F: Field>() -> impl Iterator<Item = F>
source§fn to_limbs(x: &BigUint) -> Vec<u8> ⓘ
fn to_limbs(x: &BigUint) -> Vec<u8> ⓘ
Convert a BigUint to a Vec of u8 limbs (with len NB_LIMBS).
source§impl PartialEq for U256Field
impl PartialEq for U256Field
impl Copy for U256Field
impl StructuralPartialEq for U256Field
Auto Trait Implementations§
impl Freeze for U256Field
impl RefUnwindSafe for U256Field
impl Send for U256Field
impl Sync for U256Field
impl Unpin for U256Field
impl UnwindSafe for U256Field
Blanket Implementations§
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: Copy,
impl<T> CloneToUninit for Twhere
T: Copy,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit)source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit)source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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