Trait zksync_bellman::PrimeFieldRepr

source ·
pub trait PrimeFieldRepr:
    Sized
    + Copy
    + Clone
    + Eq
    + Ord
    + Send
    + Sync
    + Default
    + Debug
    + Display
    + 'static
    + Rand
    + AsRef<[u64]>
    + AsMut<[u64]>
    + From<u64>
    + Hash
    + Serialize
    + DeserializeOwned {
Show 14 methods // Required methods fn sub_noborrow(&mut self, other: &Self); fn add_nocarry(&mut self, other: &Self); fn num_bits(&self) -> u32; fn is_zero(&self) -> bool; fn is_odd(&self) -> bool; fn is_even(&self) -> bool; fn div2(&mut self); fn shr(&mut self, amt: u32); fn mul2(&mut self); fn shl(&mut self, amt: u32); // Provided methods fn write_be<W>(&self, writer: W) -> Result<(), Error> where W: Write { ... } fn read_be<R>(&mut self, reader: R) -> Result<(), Error> where R: Read { ... } fn write_le<W>(&self, writer: W) -> Result<(), Error> where W: Write { ... } fn read_le<R>(&mut self, reader: R) -> Result<(), Error> where R: Read { ... }
}
Expand description

This trait represents a wrapper around a biginteger which can encode any element of a particular prime field. It is a smart wrapper around a sequence of u64 limbs, least-significant digit first.

Required Methods§

source

fn sub_noborrow(&mut self, other: &Self)

Subtract another represetation from this one.

source

fn add_nocarry(&mut self, other: &Self)

Add another representation to this one.

source

fn num_bits(&self) -> u32

Compute the number of bits needed to encode this number. Always a multiple of 64.

source

fn is_zero(&self) -> bool

Returns true iff this number is zero.

source

fn is_odd(&self) -> bool

Returns true iff this number is odd.

source

fn is_even(&self) -> bool

Returns true iff this number is even.

source

fn div2(&mut self)

Performs a rightwise bitshift of this number, effectively dividing it by 2.

source

fn shr(&mut self, amt: u32)

Performs a rightwise bitshift of this number by some amount.

source

fn mul2(&mut self)

Performs a leftwise bitshift of this number, effectively multiplying it by 2. Overflow is ignored.

source

fn shl(&mut self, amt: u32)

Performs a leftwise bitshift of this number by some amount.

Provided Methods§

source

fn write_be<W>(&self, writer: W) -> Result<(), Error>
where W: Write,

Writes this PrimeFieldRepr as a big endian integer.

source

fn read_be<R>(&mut self, reader: R) -> Result<(), Error>
where R: Read,

Reads a big endian integer into this representation.

source

fn write_le<W>(&self, writer: W) -> Result<(), Error>
where W: Write,

Writes this PrimeFieldRepr as a little endian integer.

source

fn read_le<R>(&mut self, reader: R) -> Result<(), Error>
where R: Read,

Reads a little endian integer into this representation.

Object Safety§

This trait is not object safe.

Implementors§

source§

impl PrimeFieldRepr for zksync_bellman::bls12_381::FqRepr

source§

impl PrimeFieldRepr for zksync_bellman::bls12_381::FrRepr

source§

impl PrimeFieldRepr for zksync_bellman::compact_bn256::FqRepr

source§

impl PrimeFieldRepr for zksync_bellman::compact_bn256::FrRepr

source§

impl PrimeFieldRepr for zksync_bellman::plonk::transparent_engine::FrRepr