zksync_bellman::compact_bn256

Struct G1

Source
pub struct G1 { /* private fields */ }

Trait Implementations§

Source§

impl Clone for G1

Source§

fn clone(&self) -> G1

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 CurveProjective for G1

Source§

type Engine = Bn256

Source§

type Scalar = Fr

Source§

type Base = Fq

Source§

type Affine = G1Affine

Source§

fn zero() -> G1

Returns the additive identity.
Source§

fn one() -> G1

Returns a fixed generator of unknown exponent.
Source§

fn is_zero(&self) -> bool

Determines if this point is the point at infinity.
Source§

fn is_normalized(&self) -> bool

Checks if the point is already “normalized” so that cheap affine conversion is possible.
Source§

fn batch_normalization(v: &mut [G1])

Normalizes a slice of projective elements so that conversion to affine is cheap.
Source§

fn double(&mut self)

Doubles this element.
Source§

fn add_assign(&mut self, other: &G1)

Adds another element to this element.
Source§

fn add_assign_mixed(&mut self, other: &<G1 as CurveProjective>::Affine)

Adds an affine element to this element.
Source§

fn negate(&mut self)

Negates this element.
Source§

fn mul_assign<S>(&mut self, other: S)
where S: Into<<<G1 as CurveProjective>::Scalar as PrimeField>::Repr>,

Performs scalar multiplication of this element.
Source§

fn into_affine(&self) -> G1Affine

Converts this element into its affine representation.
Source§

fn recommended_wnaf_for_scalar( scalar: <<G1 as CurveProjective>::Scalar as PrimeField>::Repr, ) -> usize

Recommends a wNAF window table size given a scalar. Always returns a number between 2 and 22, inclusive.
Source§

fn recommended_wnaf_for_num_scalars(num_scalars: usize) -> usize

Recommends a wNAF window size given the number of scalars you intend to multiply a base by. Always returns a number between 2 and 22, inclusive.
Source§

fn as_xyz( &self, ) -> (&<G1 as CurveProjective>::Base, &<G1 as CurveProjective>::Base, &<G1 as CurveProjective>::Base)

Returns references to underlying X, Y and Z coordinates. Users should check for infinity outside of this call
Source§

fn into_xyz_unchecked( self, ) -> (<G1 as CurveProjective>::Base, <G1 as CurveProjective>::Base, <G1 as CurveProjective>::Base)

Returns underlying X, Y and Z coordinates. Users should check for infinity outside of this call
Source§

fn from_xyz_unchecked( x: <G1 as CurveProjective>::Base, y: <G1 as CurveProjective>::Base, z: <G1 as CurveProjective>::Base, ) -> G1

Creates a point from raw X, Y and Z coordinates. Point of infinity is encoded as (0,1,0) by default. On-curve check is NOT performed
Source§

fn from_xyz_checked( _x: <G1 as CurveProjective>::Base, _y: <G1 as CurveProjective>::Base, _z: <G1 as CurveProjective>::Base, ) -> Result<G1, GroupDecodingError>

Creates a point from raw X, Y and Z coordinates. Point of infinity is encoded as (0,1,0) by default. On-curve check is performed
Source§

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

Subtracts another element from this element.
Source§

impl Debug for G1

Source§

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

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

impl Display for G1

Source§

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

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

impl From<G1> for G1Affine

Source§

fn from(p: G1) -> G1Affine

Converts to this type from the input type.
Source§

impl From<G1Affine> for G1

Source§

fn from(p: G1Affine) -> G1

Converts to this type from the input type.
Source§

impl PartialEq for G1

Source§

fn eq(&self, other: &G1) -> 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 Rand for G1

Source§

fn rand<R>(rng: &mut R) -> G1
where R: Rng,

Generates a random instance of this type using the specified source of randomness.
Source§

impl Copy for G1

Source§

impl Eq for G1

Auto Trait Implementations§

§

impl Freeze for G1

§

impl RefUnwindSafe for G1

§

impl Send for G1

§

impl Sync for G1

§

impl Unpin for G1

§

impl UnwindSafe for G1

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, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<G> GenericCurveProjective for G
where G: CurveProjective,

Source§

fn zero() -> G

Returns the additive identity.

Source§

fn one() -> G

Returns a fixed generator of unknown exponent.

Source§

fn is_zero(&self) -> bool

Determines if this point is the point at infinity.

Source§

fn batch_normalization(v: &mut [G])

Normalizes a slice of projective elements so that conversion to affine is cheap.

Source§

fn is_normalized(&self) -> bool

Checks if the point is already “normalized” so that cheap affine conversion is possible.

Source§

fn double(&mut self)

Doubles this element.

Source§

fn add_assign(&mut self, other: &G)

Adds another element to this element.

Source§

fn sub_assign(&mut self, other: &G)

Subtracts another element from this element.

Source§

fn add_assign_mixed(&mut self, other: &<G as GenericCurveProjective>::Affine)

Adds an affine element to this element.

Source§

fn negate(&mut self)

Negates this element.

Source§

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

Performs scalar multiplication of this element.

Source§

fn into_affine(&self) -> <G as GenericCurveProjective>::Affine

Converts this element into its affine representation.

Source§

fn recommended_wnaf_for_scalar( scalar: <<G as GenericCurveProjective>::Scalar as PrimeField>::Repr, ) -> usize

Recommends a wNAF window table size given a scalar. Always returns a number between 2 and 22, inclusive.

Source§

fn recommended_wnaf_for_num_scalars(num_scalars: usize) -> usize

Recommends a wNAF window size given the number of scalars you intend to multiply a base by. Always returns a number between 2 and 22, inclusive.

Source§

fn as_xyz( &self, ) -> (&<G as GenericCurveProjective>::Base, &<G as GenericCurveProjective>::Base, &<G as GenericCurveProjective>::Base)

Returns references to underlying X, Y and Z coordinates. Users should check for infinity outside of this call

Source§

fn into_xyz_unchecked( self, ) -> (<G as GenericCurveProjective>::Base, <G as GenericCurveProjective>::Base, <G as GenericCurveProjective>::Base)

Returns underlying X, Y and Z coordinates. Users should check for infinity outside of this call

Source§

fn from_xyz_unchecked( _x: <G as GenericCurveProjective>::Base, _y: <G as GenericCurveProjective>::Base, _z: <G as GenericCurveProjective>::Base, ) -> G

Creates a point from raw X, Y and Z coordinates. Point of infinity is encoded as (0,1,0) by default. On-curve check is NOT performed

Source§

fn from_xyz_checked( _x: <G as GenericCurveProjective>::Base, _y: <G as GenericCurveProjective>::Base, _z: <G as GenericCurveProjective>::Base, ) -> Result<G, GroupDecodingError>

Creates a point from raw X, Y and Z coordinates. Point of infinity is encoded as (0,1,0) by default. On-curve check is performed

Source§

type Scalar = <G as CurveProjective>::Scalar

Source§

type Base = <G as CurveProjective>::Base

Source§

type Affine = <G as CurveProjective>::Affine

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

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.