Jubjub

Struct Jubjub 

pub struct Jubjub { /* private fields */ }
Expand description

This represents an extended point (U, V, Z, T1, T2) with Z nonzero, corresponding to the affine point (U/Z, V/Z). We always have T1 * T2 = UV/Z.

You can do the following things with a point in this form:

  • Convert it into a point in the affine form.
  • Add it to an ExtendedPoint, AffineNielsPoint or ExtendedNielsPoint.
  • Double it using double().
  • Compare it with another extended point using PartialEq or ct_eq().

Implementations§

§

impl JubjubExtended

pub const fn identity() -> JubjubExtended

Constructs an extended point from the neutral element (0, 1).

pub fn is_identity(&self) -> Choice

Determines if this point is the identity.

pub fn is_small_order(&self) -> Choice

Determines if this point is of small order.

pub fn is_torsion_free(&self) -> Choice

Determines if this point is torsion free and so is contained in the prime order subgroup.

pub fn is_prime_order(&self) -> Choice

Determines if this point is prime order, or in other words that the smallest scalar multiplied by this point that produces the identity is r. This is equivalent to checking that the point is both torsion free and not the identity.

pub fn mul_by_cofactor(&self) -> JubjubExtended

Multiplies this element by the cofactor 8.

pub fn to_niels(&self) -> ExtendedNielsPoint

Performs a pre-processing step that produces an ExtendedNielsPoint for use in multiple additions.

pub fn double(&self) -> JubjubExtended

Computes the doubling of a point more efficiently than a point can be added to itself.

Trait Implementations§

§

impl<'b> Add<&'b ExtendedNielsPoint> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, other: &'b ExtendedNielsPoint) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b ExtendedNielsPoint> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: &'b ExtendedNielsPoint) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubAffine> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, other: &'b JubjubAffine) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubAffine> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: &'b JubjubAffine) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubAffineNiels> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, other: &'b JubjubAffineNiels) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubAffineNiels> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: &'b JubjubAffineNiels) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubExtended> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, other: &'b JubjubExtended) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubExtended> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: &'b JubjubExtended) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubSubgroup> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, other: &'b JubjubSubgroup) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> Add<&'b JubjubSubgroup> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: &'b JubjubSubgroup) -> JubjubExtended

Performs the + operation. Read more
§

impl<'a> Add<ExtendedNielsPoint> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: ExtendedNielsPoint) -> JubjubExtended

Performs the + operation. Read more
§

impl Add<ExtendedNielsPoint> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: ExtendedNielsPoint) -> JubjubExtended

Performs the + operation. Read more
§

impl<'a> Add<JubjubAffine> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubAffine) -> JubjubExtended

Performs the + operation. Read more
§

impl Add<JubjubAffine> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubAffine) -> JubjubExtended

Performs the + operation. Read more
§

impl<'a> Add<JubjubAffineNiels> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubAffineNiels) -> JubjubExtended

Performs the + operation. Read more
§

impl Add<JubjubAffineNiels> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubAffineNiels) -> JubjubExtended

Performs the + operation. Read more
§

impl<'a> Add<JubjubExtended> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubExtended) -> JubjubExtended

Performs the + operation. Read more
§

impl<'a> Add<JubjubSubgroup> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubSubgroup) -> JubjubExtended

Performs the + operation. Read more
§

impl Add<JubjubSubgroup> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubSubgroup) -> JubjubExtended

Performs the + operation. Read more
§

impl Add for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the + operator.
§

fn add(self, rhs: JubjubExtended) -> JubjubExtended

Performs the + operation. Read more
§

impl<'b> AddAssign<&'b ExtendedNielsPoint> for JubjubExtended

§

fn add_assign(&mut self, rhs: &'b ExtendedNielsPoint)

Performs the += operation. Read more
§

impl<'b> AddAssign<&'b JubjubAffine> for JubjubExtended

§

fn add_assign(&mut self, rhs: &'b JubjubAffine)

Performs the += operation. Read more
§

impl<'b> AddAssign<&'b JubjubAffineNiels> for JubjubExtended

§

fn add_assign(&mut self, rhs: &'b JubjubAffineNiels)

Performs the += operation. Read more
§

impl<'b> AddAssign<&'b JubjubExtended> for JubjubExtended

§

fn add_assign(&mut self, rhs: &'b JubjubExtended)

Performs the += operation. Read more
§

impl<'b> AddAssign<&'b JubjubSubgroup> for JubjubExtended

§

fn add_assign(&mut self, rhs: &'b JubjubSubgroup)

Performs the += operation. Read more
§

impl AddAssign<ExtendedNielsPoint> for JubjubExtended

§

fn add_assign(&mut self, rhs: ExtendedNielsPoint)

Performs the += operation. Read more
§

impl AddAssign<JubjubAffine> for JubjubExtended

§

fn add_assign(&mut self, rhs: JubjubAffine)

Performs the += operation. Read more
§

impl AddAssign<JubjubAffineNiels> for JubjubExtended

§

fn add_assign(&mut self, rhs: JubjubAffineNiels)

Performs the += operation. Read more
§

impl AddAssign<JubjubSubgroup> for JubjubExtended

§

fn add_assign(&mut self, rhs: JubjubSubgroup)

Performs the += operation. Read more
§

impl AddAssign for JubjubExtended

§

fn add_assign(&mut self, rhs: JubjubExtended)

Performs the += operation. Read more
§

impl CircuitCurve for JubjubExtended

§

const COFACTOR: u128 = 8

Cofactor of the curve.
§

const NUM_BITS_SUBGROUP: u32 = 252

How many bits are needed to represent an element of the scalar field of the curve subgroup. This is the log2 rounded up of the curve order divided by the cofactor.
§

type Base = Fq

Base field over which the EC is defined.
§

type CryptographicGroup = JubjubSubgroup

Cryptographic group.
§

fn coordinates( &self, ) -> Option<(<JubjubExtended as CircuitCurve>::Base, <JubjubExtended as CircuitCurve>::Base)>

Returns the coordinates.
§

fn from_xy( x: <JubjubExtended as CircuitCurve>::Base, y: <JubjubExtended as CircuitCurve>::Base, ) -> Option<JubjubExtended>

Constructs a point in the curve from its coordinates
§

fn into_subgroup(self) -> <JubjubExtended as CircuitCurve>::CryptographicGroup

Checks that the point is part of the subgroup.
§

impl Clone for JubjubExtended

§

fn clone(&self) -> JubjubExtended

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl CofactorCurve for JubjubExtended

§

impl CofactorGroup for JubjubExtended

§

type Subgroup = JubjubSubgroup

The large prime-order subgroup in which cryptographic operations are performed. If Self implements PrimeGroup, then Self::Subgroup may be Self.
§

fn clear_cofactor(&self) -> <JubjubExtended as CofactorGroup>::Subgroup

Maps self to the prime-order subgroup by multiplying this element by some k-multiple of the cofactor. Read more
§

fn into_subgroup(self) -> CtOption<<JubjubExtended as CofactorGroup>::Subgroup>

Returns self if it is contained in the prime-order subgroup. Read more
§

fn is_torsion_free(&self) -> Choice

Determines if this element is “torsion free”, i.e., is contained in the prime-order subgroup. Read more
§

fn is_small_order(&self) -> Choice

Determines if this element is of small order. Read more
§

impl ConditionallySelectable for JubjubExtended

§

fn conditional_select( a: &JubjubExtended, b: &JubjubExtended, choice: Choice, ) -> JubjubExtended

Select a or b according to choice. Read more
Source§

fn conditional_assign(&mut self, other: &Self, choice: Choice)

Conditionally assign other to self, according to choice. Read more
Source§

fn conditional_swap(a: &mut Self, b: &mut Self, choice: Choice)

Conditionally swap self and other if choice == 1; otherwise, reassign both unto themselves. Read more
§

impl ConstantTimeEq for JubjubExtended

§

fn ct_eq(&self, other: &JubjubExtended) -> Choice

Determine if two items are equal. Read more
Source§

fn ct_ne(&self, other: &Self) -> Choice

Determine if two items are NOT equal. Read more
§

impl Curve for JubjubExtended

§

type AffineRepr = JubjubAffine

The affine representation for this elliptic curve.
§

fn batch_normalize( p: &[JubjubExtended], q: &mut [<JubjubExtended as Curve>::AffineRepr], )

Converts a batch of projective elements into affine elements. This function will panic if p.len() != q.len().
§

fn to_affine(&self) -> <JubjubExtended as Curve>::AffineRepr

Converts this element into its affine representation.
§

impl Debug for JubjubExtended

§

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

Formats the value using the given formatter. Read more
§

impl Default for JubjubExtended

§

fn default() -> JubjubExtended

Returns the identity.

§

impl Display for JubjubExtended

§

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

Formats the value using the given formatter. Read more
§

impl EdwardsCurve for JubjubExtended

§

const A: <JubjubExtended as CircuitCurve>::Base

A parameter.
§

const D: <JubjubExtended as CircuitCurve>::Base

D parameter.
§

impl<'a> From<&'a JubjubExtended> for JubjubAffine

§

fn from(extended: &'a JubjubExtended) -> JubjubAffine

Constructs an affine point from an extended point using the map (U, V, Z, T1, T2) => (U/Z, V/Z) as Z is always nonzero. This requires a field inversion and so it is recommended to perform these in a batch using [batch_normalize] instead.

§

impl<'a> From<&'a JubjubSubgroup> for &'a JubjubExtended

§

fn from(val: &'a JubjubSubgroup) -> &'a JubjubExtended

Converts to this type from the input type.
§

impl From<JubjubAffine> for JubjubExtended

§

fn from(affine: JubjubAffine) -> JubjubExtended

Constructs an extended point (with Z = 1) from an affine point using the map (u, v) => (u, v, 1, u, v).

§

impl From<JubjubExtended> for JubjubAffine

§

fn from(extended: JubjubExtended) -> JubjubAffine

Converts to this type from the input type.
§

impl From<JubjubSubgroup> for JubjubExtended

§

fn from(val: JubjubSubgroup) -> JubjubExtended

Converts to this type from the input type.
§

impl Group for JubjubExtended

§

type Scalar = Fr

Scalars modulo the order of this group’s scalar field.
§

fn random(rng: impl RngCore) -> JubjubExtended

Returns an element chosen uniformly at random from the non-identity elements of this group. Read more
§

fn identity() -> JubjubExtended

Returns the additive identity, also known as the “neutral element”.
§

fn generator() -> JubjubExtended

Returns a fixed generator of the prime-order subgroup.
§

fn is_identity(&self) -> Choice

Determines if this point is the identity.
§

fn double(&self) -> JubjubExtended

Doubles this element.
§

impl GroupEncoding for JubjubExtended

§

type Repr = [u8; 32]

The encoding of group elements. Read more
§

fn from_bytes( bytes: &<JubjubExtended as GroupEncoding>::Repr, ) -> CtOption<JubjubExtended>

Attempts to deserialize a group element from its encoding.
§

fn from_bytes_unchecked( bytes: &<JubjubExtended as GroupEncoding>::Repr, ) -> CtOption<JubjubExtended>

Attempts to deserialize a group element, not checking if the element is valid. Read more
§

fn to_bytes(&self) -> <JubjubExtended as GroupEncoding>::Repr

Converts this element into its byte encoding. This may or may not support encoding the identity.
§

impl MapToCurveCPU<JubjubExtended> for JubjubExtended

§

fn map_to_curve(u: &<JubjubExtended as CircuitCurve>::Base) -> JubjubSubgroup

Map an element of the base field (a coordinate) to a pair of coordinates that satisfy the underlying curve equation.
§

impl MapToEdwardsParams<Fq> for JubjubExtended

§

const MONT_J: Fq

J constant of Montgomery curve: K * y^2 = x^3 + J * x^2 + x.
§

const MONT_K: Fq

K constant of Montgomery curve: K * y^2 = x^3 + J * x^2 + x.
§

impl<'b> Mul<&'b Fr> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the * operator.
§

fn mul(self, other: &'b Fr) -> JubjubExtended

Performs the * operation. Read more
§

impl<'b> Mul<&'b Fr> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the * operator.
§

fn mul(self, rhs: &'b Fr) -> JubjubExtended

Performs the * operation. Read more
§

impl<'a> Mul<Fr> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the * operator.
§

fn mul(self, rhs: Fr) -> JubjubExtended

Performs the * operation. Read more
§

impl Mul<Fr> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the * operator.
§

fn mul(self, rhs: Fr) -> JubjubExtended

Performs the * operation. Read more
§

impl<'b> MulAssign<&'b Fr> for JubjubExtended

§

fn mul_assign(&mut self, rhs: &'b Fr)

Performs the *= operation. Read more
§

impl MulAssign<Fr> for JubjubExtended

§

fn mul_assign(&mut self, rhs: Fr)

Performs the *= operation. Read more
§

impl Neg for JubjubExtended

§

fn neg(self) -> JubjubExtended

Computes the negation of a point P = (U, V, Z, T) as -P = (-U, V, Z, -T1, T2). The choice of T1 is made without loss of generality.

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

impl PartialEq for JubjubExtended

§

fn eq(&self, other: &JubjubExtended) -> 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.
§

impl<'b> Sub<&'b ExtendedNielsPoint> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, other: &'b ExtendedNielsPoint) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b ExtendedNielsPoint> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: &'b ExtendedNielsPoint) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubAffine> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, other: &'b JubjubAffine) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubAffine> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: &'b JubjubAffine) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubAffineNiels> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, other: &'b JubjubAffineNiels) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubAffineNiels> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: &'b JubjubAffineNiels) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubExtended> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, other: &'b JubjubExtended) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubExtended> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: &'b JubjubExtended) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubSubgroup> for &JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, other: &'b JubjubSubgroup) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> Sub<&'b JubjubSubgroup> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: &'b JubjubSubgroup) -> JubjubExtended

Performs the - operation. Read more
§

impl<'a> Sub<ExtendedNielsPoint> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: ExtendedNielsPoint) -> JubjubExtended

Performs the - operation. Read more
§

impl Sub<ExtendedNielsPoint> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: ExtendedNielsPoint) -> JubjubExtended

Performs the - operation. Read more
§

impl<'a> Sub<JubjubAffine> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubAffine) -> JubjubExtended

Performs the - operation. Read more
§

impl Sub<JubjubAffine> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubAffine) -> JubjubExtended

Performs the - operation. Read more
§

impl<'a> Sub<JubjubAffineNiels> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubAffineNiels) -> JubjubExtended

Performs the - operation. Read more
§

impl Sub<JubjubAffineNiels> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubAffineNiels) -> JubjubExtended

Performs the - operation. Read more
§

impl<'a> Sub<JubjubExtended> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubExtended) -> JubjubExtended

Performs the - operation. Read more
§

impl<'a> Sub<JubjubSubgroup> for &'a JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubSubgroup) -> JubjubExtended

Performs the - operation. Read more
§

impl Sub<JubjubSubgroup> for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubSubgroup) -> JubjubExtended

Performs the - operation. Read more
§

impl Sub for JubjubExtended

§

type Output = JubjubExtended

The resulting type after applying the - operator.
§

fn sub(self, rhs: JubjubExtended) -> JubjubExtended

Performs the - operation. Read more
§

impl<'b> SubAssign<&'b ExtendedNielsPoint> for JubjubExtended

§

fn sub_assign(&mut self, rhs: &'b ExtendedNielsPoint)

Performs the -= operation. Read more
§

impl<'b> SubAssign<&'b JubjubAffine> for JubjubExtended

§

fn sub_assign(&mut self, rhs: &'b JubjubAffine)

Performs the -= operation. Read more
§

impl<'b> SubAssign<&'b JubjubAffineNiels> for JubjubExtended

§

fn sub_assign(&mut self, rhs: &'b JubjubAffineNiels)

Performs the -= operation. Read more
§

impl<'b> SubAssign<&'b JubjubExtended> for JubjubExtended

§

fn sub_assign(&mut self, rhs: &'b JubjubExtended)

Performs the -= operation. Read more
§

impl<'b> SubAssign<&'b JubjubSubgroup> for JubjubExtended

§

fn sub_assign(&mut self, rhs: &'b JubjubSubgroup)

Performs the -= operation. Read more
§

impl SubAssign<ExtendedNielsPoint> for JubjubExtended

§

fn sub_assign(&mut self, rhs: ExtendedNielsPoint)

Performs the -= operation. Read more
§

impl SubAssign<JubjubAffine> for JubjubExtended

§

fn sub_assign(&mut self, rhs: JubjubAffine)

Performs the -= operation. Read more
§

impl SubAssign<JubjubAffineNiels> for JubjubExtended

§

fn sub_assign(&mut self, rhs: JubjubAffineNiels)

Performs the -= operation. Read more
§

impl SubAssign<JubjubSubgroup> for JubjubExtended

§

fn sub_assign(&mut self, rhs: JubjubSubgroup)

Performs the -= operation. Read more
§

impl SubAssign for JubjubExtended

§

fn sub_assign(&mut self, rhs: JubjubExtended)

Performs the -= operation. Read more
§

impl<T> Sum<T> for JubjubExtended

§

fn sum<I>(iter: I) -> JubjubExtended
where I: Iterator<Item = T>,

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

impl Copy for JubjubExtended

§

impl Eq for JubjubExtended

Auto Trait Implementations§

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

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

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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
§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
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§

fn to_string(&self) -> String

Converts the given value to a String. Read more
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T, Scalar> FftGroup<Scalar> for T
where Scalar: Field, T: Copy + Send + Sync + 'static + GroupOpsOwned + ScalarMulOwned<Scalar>,

§

impl<T, Scalar> FftGroup<Scalar> for T
where Scalar: Field, T: Copy + Send + Sync + 'static + GroupOpsOwned + ScalarMulOwned<Scalar>,

§

impl<T, Rhs, Output> GroupOps<Rhs, Output> for T
where T: Add<Rhs, Output = Output> + Sub<Rhs, Output = Output> + AddAssign<Rhs> + SubAssign<Rhs>,

§

impl<T, Rhs, Output> GroupOpsOwned<Rhs, Output> for T
where T: for<'r> GroupOps<&'r Rhs, Output>,

§

impl<T, Rhs, Output> ScalarMul<Rhs, Output> for T
where T: Mul<Rhs, Output = Output> + MulAssign<Rhs>,

§

impl<T, Rhs, Output> ScalarMulOwned<Rhs, Output> for T
where T: for<'r> ScalarMul<&'r Rhs, Output>,

§

impl<T> SyncDeps for T