Struct snarkvm_circuit::Group
pub struct Group<E>where
E: Environment,{ /* private fields */ }
Implementations§
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub fn from_x_coordinate(x: Field<E>) -> Group<E>
pub fn from_x_coordinate(x: Field<E>) -> Group<E>
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.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub fn from_xy_coordinates(x: Field<E>, y: Field<E>) -> Group<E>
pub fn from_xy_coordinates(x: Field<E>, y: Field<E>) -> Group<E>
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.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub 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.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub fn to_x_coordinate(&self) -> Field<E>
pub fn to_x_coordinate(&self) -> Field<E>
Returns the x-coordinate of the group element.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub fn to_y_coordinate(&self) -> Field<E>
pub fn to_y_coordinate(&self) -> Field<E>
Returns the y-coordinate of the group element.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub 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§
§impl<E> Add<&Group<E>> for &Group<E>where
E: Environment,
impl<E> Add<&Group<E>> for &Group<E>where E: Environment,
§impl<E> Add<&Group<E>> for Group<E>where
E: Environment,
impl<E> Add<&Group<E>> for Group<E>where E: Environment,
§impl<E> Add<Group<E>> for Group<E>where
E: Environment,
impl<E> Add<Group<E>> for Group<E>where E: Environment,
§impl<E> AddAssign<&Group<E>> for Group<E>where
E: Environment,
impl<E> AddAssign<&Group<E>> for Group<E>where E: Environment,
§fn add_assign(&mut self, other: &Group<E>)
fn add_assign(&mut self, other: &Group<E>)
+=
operation. Read more§impl<E> AddAssign<Group<E>> for Group<E>where
E: Environment,
impl<E> AddAssign<Group<E>> for Group<E>where E: Environment,
§fn add_assign(&mut self, other: Group<E>)
fn add_assign(&mut self, other: Group<E>)
+=
operation. Read more§impl<E> Clone for Group<E>where
E: Clone + Environment,
impl<E> Clone for Group<E>where E: Clone + Environment,
§impl<E> Debug for Group<E>where
E: Environment,
impl<E> Debug for Group<E>where E: Environment,
§impl<E> Display for Group<E>where
E: Environment,
impl<E> Display for Group<E>where E: Environment,
§impl<E> Double for Group<E>where
E: Environment,
impl<E> Double for Group<E>where E: Environment,
§impl<E> Eject for Group<E>where
E: Environment,
impl<E> Eject for Group<E>where E: Environment,
§fn eject_mode(&self) -> Mode
fn eject_mode(&self) -> Mode
Ejects the mode of the group element.
§fn eject_value(&self) -> <Group<E> as Eject>::Primitive
fn eject_value(&self) -> <Group<E> as Eject>::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.§impl<E> Equal<Group<E>> for Group<E>where
E: Environment,
impl<E> Equal<Group<E>> for Group<E>where E: Environment,
§fn is_equal(&self, other: &Group<E>) -> <Group<E> as Equal<Group<E>>>::Output
fn is_equal(&self, other: &Group<E>) -> <Group<E> as Equal<Group<E>>>::Output
Returns true
if self
and other
are equal.
This method costs 8 constraints.
§fn is_not_equal(
&self,
other: &Group<E>
) -> <Group<E> as Equal<Group<E>>>::Output
fn is_not_equal( &self, other: &Group<E> ) -> <Group<E> as Equal<Group<E>>>::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>
§impl<E> From<&Address<E>> for Group<E>where
E: Environment,
impl<E> From<&Address<E>> for Group<E>where E: Environment,
§impl<E> From<&Group<E>> for Address<E>where
E: Environment,
impl<E> From<&Group<E>> for Address<E>where E: Environment,
§impl<E> From<&Group<E>> for LinearCombination<<E as Environment>::BaseField>where
E: Environment,
impl<E> From<&Group<E>> for LinearCombination<<E as Environment>::BaseField>where E: Environment,
§fn from(group: &Group<E>) -> LinearCombination<<E as Environment>::BaseField>
fn from(group: &Group<E>) -> LinearCombination<<E as Environment>::BaseField>
§impl<E> From<Address<E>> for Group<E>where
E: Environment,
impl<E> From<Address<E>> for Group<E>where E: Environment,
§impl<E> From<Group<E>> for Address<E>where
E: Environment,
impl<E> From<Group<E>> for Address<E>where E: Environment,
§impl<E> From<Group<E>> for LinearCombination<<E as Environment>::BaseField>where
E: Environment,
impl<E> From<Group<E>> for LinearCombination<<E as Environment>::BaseField>where E: Environment,
§fn from(group: Group<E>) -> LinearCombination<<E as Environment>::BaseField>
fn from(group: Group<E>) -> LinearCombination<<E as Environment>::BaseField>
§impl<E> FromBits for Group<E>where
E: Environment,
impl<E> FromBits for Group<E>where E: Environment,
§fn from_bits_le(bits_le: &[<Group<E> as FromBits>::Boolean]) -> Group<E>
fn from_bits_le(bits_le: &[<Group<E> as FromBits>::Boolean]) -> Group<E>
Initializes a new group element from the x-coordinate as a list of little-endian bits without trailing zeros.
§fn from_bits_be(bits_be: &[<Group<E> as FromBits>::Boolean]) -> Group<E>
fn from_bits_be(bits_be: &[<Group<E> as FromBits>::Boolean]) -> Group<E>
Initializes a new group element from the x-coordinate as a list of big-endian bits without leading zeros.
type Boolean = Boolean<E>
§impl<E> FromStr for Group<E>where
E: Environment,
impl<E> FromStr for Group<E>where E: Environment,
§impl<E> Inject for Group<E>where
E: Environment,
impl<E> Inject for Group<E>where E: Environment,
§fn new(mode: Mode, group: <Group<E> as Inject>::Primitive) -> Group<E>
fn new(mode: Mode, group: <Group<E> as Inject>::Primitive) -> Group<E>
Initializes a new affine group element.
For safety, the resulting point is always enforced to be on the curve with constraints. regardless of whether the y-coordinate was recovered.
type Primitive = Group<<E as Environment>::Network>
§impl<E> Metrics<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>where
E: Environment,
impl<E> Metrics<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>where E: Environment,
§impl<E> Mul<&[Boolean<E>]> for &Group<E>where
E: Environment,
impl<E> Mul<&[Boolean<E>]> for &Group<E>where E: Environment,
§impl<E> Mul<&[Boolean<E>]> for Group<E>where
E: Environment,
impl<E> Mul<&[Boolean<E>]> for Group<E>where E: Environment,
§impl<E> Mul<&Group<E>> for &[Boolean<E>]where
E: Environment,
impl<E> Mul<&Group<E>> for &[Boolean<E>]where E: Environment,
§impl<E> Mul<&Group<E>> for &Scalar<E>where
E: Environment,
impl<E> Mul<&Group<E>> for &Scalar<E>where E: Environment,
§impl<E> Mul<&Group<E>> for Scalar<E>where
E: Environment,
impl<E> Mul<&Group<E>> for Scalar<E>where E: Environment,
§impl<E> Mul<&Scalar<E>> for &Group<E>where
E: Environment,
impl<E> Mul<&Scalar<E>> for &Group<E>where E: Environment,
§impl<E> Mul<&Scalar<E>> for Group<E>where
E: Environment,
impl<E> Mul<&Scalar<E>> for Group<E>where E: Environment,
§impl<E> Mul<Group<E>> for &[Boolean<E>]where
E: Environment,
impl<E> Mul<Group<E>> for &[Boolean<E>]where E: Environment,
§impl<E> Mul<Group<E>> for &Scalar<E>where
E: Environment,
impl<E> Mul<Group<E>> for &Scalar<E>where E: Environment,
§impl<E> Mul<Group<E>> for Scalar<E>where
E: Environment,
impl<E> Mul<Group<E>> for Scalar<E>where E: Environment,
§impl<E> Mul<Scalar<E>> for &Group<E>where
E: Environment,
impl<E> Mul<Scalar<E>> for &Group<E>where E: Environment,
§impl<E> Mul<Scalar<E>> for Group<E>where
E: Environment,
impl<E> Mul<Scalar<E>> for Group<E>where E: Environment,
§impl<E> MulAssign<&[Boolean<E>]> for Group<E>where
E: Environment,
impl<E> MulAssign<&[Boolean<E>]> for Group<E>where E: Environment,
§fn mul_assign(&mut self, other: &[Boolean<E>])
fn mul_assign(&mut self, other: &[Boolean<E>])
*=
operation. Read more§impl<E> MulAssign<&Scalar<E>> for Group<E>where
E: Environment,
impl<E> MulAssign<&Scalar<E>> for Group<E>where E: Environment,
§fn mul_assign(&mut self, other: &Scalar<E>)
fn mul_assign(&mut self, other: &Scalar<E>)
*=
operation. Read more§impl<E, const N: usize> MulAssign<[Boolean<E>; N]> for Group<E>where
E: Environment,
impl<E, const N: usize> MulAssign<[Boolean<E>; N]> for Group<E>where E: Environment,
§fn mul_assign(&mut self, other: [Boolean<E>; N])
fn mul_assign(&mut self, other: [Boolean<E>; N])
*=
operation. Read more§impl<E> MulAssign<Scalar<E>> for Group<E>where
E: Environment,
impl<E> MulAssign<Scalar<E>> for Group<E>where E: Environment,
§fn mul_assign(&mut self, other: Scalar<E>)
fn mul_assign(&mut self, other: Scalar<E>)
*=
operation. Read more§impl<E> Neg for &Group<E>where
E: Environment,
impl<E> Neg for &Group<E>where E: Environment,
§impl<E> Neg for Group<E>where
E: Environment,
impl<E> Neg for Group<E>where E: Environment,
§impl<E> OutputMode<dyn Add<Group<E>, Output = Group<E>>> for Group<E>where
E: Environment,
impl<E> OutputMode<dyn Add<Group<E>, Output = Group<E>>> for Group<E>where E: Environment,
§impl<E> OutputMode<dyn Neg<Output = Group<E>>> for Group<E>where
E: Environment,
impl<E> OutputMode<dyn Neg<Output = Group<E>>> for Group<E>where E: Environment,
§impl<E> OutputMode<dyn Sub<Group<E>, Output = Group<E>>> for Group<E>where
E: Environment,
impl<E> OutputMode<dyn Sub<Group<E>, Output = Group<E>>> for Group<E>where E: Environment,
§impl<E> OutputMode<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>where
E: Environment,
impl<E> OutputMode<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>> for Group<E>where E: Environment,
type Case = (CircuitType<Boolean<E>>, Mode, Mode)
§fn output_mode(
parameter: &<Group<E> as OutputMode<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>>>::Case
) -> Mode
fn output_mode( parameter: &<Group<E> as OutputMode<dyn Ternary<Output = Group<E>, Boolean = Boolean<E>>>>::Case ) -> Mode
§impl<E> Parser for Group<E>where
E: Environment,
impl<E> Parser for Group<E>where E: Environment,
§impl<E> Sub<&Group<E>> for &Group<E>where
E: Environment,
impl<E> Sub<&Group<E>> for &Group<E>where E: Environment,
§impl<E> Sub<&Group<E>> for Group<E>where
E: Environment,
impl<E> Sub<&Group<E>> for Group<E>where E: Environment,
§impl<E> Sub<Group<E>> for Group<E>where
E: Environment,
impl<E> Sub<Group<E>> for Group<E>where E: Environment,
§impl<E> SubAssign<&Group<E>> for Group<E>where
E: Environment,
impl<E> SubAssign<&Group<E>> for Group<E>where E: Environment,
§fn sub_assign(&mut self, other: &Group<E>)
fn sub_assign(&mut self, other: &Group<E>)
-=
operation. Read more§impl<E> SubAssign<Group<E>> for Group<E>where
E: Environment,
impl<E> SubAssign<Group<E>> for Group<E>where E: Environment,
§fn sub_assign(&mut self, other: Group<E>)
fn sub_assign(&mut self, other: Group<E>)
-=
operation. Read more§impl<E> Ternary for Group<E>where
E: Environment,
impl<E> Ternary for Group<E>where E: Environment,
§impl<E> ToBits for &Group<E>where
E: Environment,
impl<E> ToBits for &Group<E>where E: Environment,
§fn to_bits_le(&self) -> Vec<<&Group<E> as ToBits>::Boolean, Global>
fn to_bits_le(&self) -> Vec<<&Group<E> as ToBits>::Boolean, Global>
Outputs the little-endian bit representation of self.x
without trailing zeros.
§fn to_bits_be(&self) -> Vec<<&Group<E> as ToBits>::Boolean, Global>
fn to_bits_be(&self) -> Vec<<&Group<E> as ToBits>::Boolean, Global>
Outputs the big-endian bit representation of self.x
without leading zeros.
type Boolean = Boolean<E>
§impl<E> ToBits for Group<E>where
E: Environment,
impl<E> ToBits for Group<E>where E: Environment,
§fn to_bits_le(&self) -> Vec<<Group<E> as ToBits>::Boolean, Global>
fn to_bits_le(&self) -> Vec<<Group<E> as ToBits>::Boolean, Global>
Outputs the little-endian bit representation of self.x
without trailing zeros.
§fn to_bits_be(&self) -> Vec<<Group<E> as ToBits>::Boolean, Global>
fn to_bits_be(&self) -> Vec<<Group<E> as ToBits>::Boolean, Global>
Outputs the big-endian bit representation of self.x
without leading zeros.