Struct snarkvm_circuit_types_group::Group
source · pub struct Group<E: Environment> { /* private fields */ }
Implementations§
source§impl<E: Environment> Group<E>
impl<E: Environment> Group<E>
sourcepub fn from_x_coordinate(x: Field<E>) -> Self
pub fn from_x_coordinate(x: Field<E>) -> Self
Initializes an affine group element from a given x-coordinate field element. For safety, the resulting point is always enforced to be on the curve with constraints.
source§impl<E: Environment> Group<E>
impl<E: Environment> Group<E>
sourcepub fn from_xy_coordinates(x: Field<E>, y: Field<E>) -> Self
pub fn from_xy_coordinates(x: Field<E>, y: Field<E>) -> Self
Initializes an affine group element from a given x- and y-coordinate field element. For safety, the resulting point is always enforced to be on the curve and in the subgroup.
source§impl<E: Environment> Group<E>
impl<E: Environment> Group<E>
sourcepub fn mul_by_cofactor(&self) -> Group<E>
pub fn mul_by_cofactor(&self) -> Group<E>
Returns the product of the group element and the cofactor.
source§impl<E: Environment> Group<E>
impl<E: Environment> Group<E>
sourcepub fn to_x_coordinate(&self) -> Field<E>
pub fn to_x_coordinate(&self) -> Field<E>
Returns the x-coordinate of the group element.
source§impl<E: Environment> Group<E>
impl<E: Environment> Group<E>
sourcepub fn to_y_coordinate(&self) -> Field<E>
pub fn to_y_coordinate(&self) -> Field<E>
Returns the y-coordinate of the group element.
source§impl<E: Environment> Group<E>
impl<E: Environment> Group<E>
sourcepub fn enforce_on_curve(&self)
pub fn enforce_on_curve(&self)
Checks (x, y)
is on the curve.
Ensure ax^2 + y^2 = 1 + dx^2y^2 by checking that y^2 * (dx^2 - 1) = (ax^2 - 1)
Trait Implementations§
source§impl<E: Environment> AddAssign<&Group<E>> for Group<E>
impl<E: Environment> AddAssign<&Group<E>> for Group<E>
source§fn add_assign(&mut self, other: &Self)
fn add_assign(&mut self, other: &Self)
+=
operation. Read moresource§impl<E: Environment> AddAssign<Group<E>> for Group<E>
impl<E: Environment> AddAssign<Group<E>> for Group<E>
source§fn add_assign(&mut self, other: Self)
fn add_assign(&mut self, other: Self)
+=
operation. Read moresource§impl<E: Environment> Debug for Group<E>
impl<E: Environment> Debug for Group<E>
source§impl<E: Environment> Display for Group<E>
impl<E: Environment> Display for Group<E>
source§impl<E: Environment> Double for Group<E>
impl<E: Environment> Double for Group<E>
source§impl<E: Environment> Eject for Group<E>
impl<E: Environment> Eject for Group<E>
source§fn eject_mode(&self) -> Mode
fn eject_mode(&self) -> Mode
Ejects the mode of the group element.
source§fn eject_value(&self) -> Self::Primitive
fn eject_value(&self) -> Self::Primitive
Ejects the group as a constant group element.
type Primitive = Group<<E as Environment>::Network>
source§fn eject(&self) -> (Mode, Self::Primitive)
fn eject(&self) -> (Mode, Self::Primitive)
source§fn is_constant(&self) -> bool
fn is_constant(&self) -> bool
true
if the circuit is a constant.source§fn is_private(&self) -> bool
fn is_private(&self) -> bool
true
if the circuit is a private.source§impl<E: Environment> Equal<Group<E>> for Group<E>
impl<E: Environment> Equal<Group<E>> for Group<E>
source§fn is_equal(&self, other: &Self) -> Self::Output
fn is_equal(&self, other: &Self) -> Self::Output
Returns true
if self
and other
are equal.
This method costs 8 constraints.
source§fn is_not_equal(&self, other: &Self) -> Self::Output
fn is_not_equal(&self, other: &Self) -> Self::Output
Returns true
if self
and other
are not equal.
This method constructs a boolean that indicates if
self
and other
are not equal to each other.
This method costs 8 constraints.
type Output = Boolean<E>
source§impl<E: Environment> From<&Group<E>> for LinearCombination<E::BaseField>
impl<E: Environment> From<&Group<E>> for LinearCombination<E::BaseField>
source§impl<E: Environment> From<Group<E>> for LinearCombination<E::BaseField>
impl<E: Environment> From<Group<E>> for LinearCombination<E::BaseField>
source§impl<E: Environment> FromBits for Group<E>
impl<E: Environment> FromBits for Group<E>
source§fn from_bits_le(bits_le: &[Self::Boolean]) -> Self
fn from_bits_le(bits_le: &[Self::Boolean]) -> Self
Initializes a new group element from the x-coordinate as a list of little-endian bits without trailing zeros.
source§fn from_bits_be(bits_be: &[Self::Boolean]) -> Self
fn from_bits_be(bits_be: &[Self::Boolean]) -> Self
Initializes a new group element from the x-coordinate as a list of big-endian bits without leading zeros.
type Boolean = Boolean<E>
source§impl<E: Environment> FromStr for Group<E>
impl<E: Environment> FromStr for Group<E>
source§impl<E: Environment> Inject for Group<E>
impl<E: Environment> Inject for Group<E>
source§impl<E: Environment> Metrics<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>
impl<E: Environment> Metrics<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>
source§impl<E: Environment> MulAssign<&[Boolean<E>]> for Group<E>
impl<E: Environment> MulAssign<&[Boolean<E>]> for Group<E>
source§fn mul_assign(&mut self, other: &[Boolean<E>])
fn mul_assign(&mut self, other: &[Boolean<E>])
*=
operation. Read moresource§impl<E: Environment> MulAssign<&Scalar<E>> for Group<E>
impl<E: Environment> MulAssign<&Scalar<E>> for Group<E>
source§fn mul_assign(&mut self, other: &Scalar<E>)
fn mul_assign(&mut self, other: &Scalar<E>)
*=
operation. Read moresource§impl<E: Environment> MulAssign<Scalar<E>> for Group<E>
impl<E: Environment> MulAssign<Scalar<E>> for Group<E>
source§fn mul_assign(&mut self, other: Scalar<E>)
fn mul_assign(&mut self, other: Scalar<E>)
*=
operation. Read moresource§impl<E: Environment> Neg for &Group<E>
impl<E: Environment> Neg for &Group<E>
source§impl<E: Environment> Neg for Group<E>
impl<E: Environment> Neg for Group<E>
source§impl<E: Environment> OutputMode<dyn Add<Group<E>, Output = Group<E>>> for Group<E>
impl<E: Environment> OutputMode<dyn Add<Group<E>, Output = Group<E>>> for Group<E>
source§impl<E: Environment> OutputMode<dyn Neg<Output = Group<E>>> for Group<E>
impl<E: Environment> OutputMode<dyn Neg<Output = Group<E>>> for Group<E>
source§impl<E: Environment> OutputMode<dyn Sub<Group<E>, Output = Group<E>>> for Group<E>
impl<E: Environment> OutputMode<dyn Sub<Group<E>, Output = Group<E>>> for Group<E>
source§impl<E: Environment> OutputMode<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>
impl<E: Environment> OutputMode<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>
source§impl<E: Environment> Parser for Group<E>
impl<E: Environment> Parser for Group<E>
source§impl<E: Environment> SubAssign<&Group<E>> for Group<E>
impl<E: Environment> SubAssign<&Group<E>> for Group<E>
source§fn sub_assign(&mut self, other: &Self)
fn sub_assign(&mut self, other: &Self)
-=
operation. Read moresource§impl<E: Environment> SubAssign<Group<E>> for Group<E>
impl<E: Environment> SubAssign<Group<E>> for Group<E>
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
-=
operation. Read more