Struct snarkvm_console_program::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_coordinate: Field<E>) -> Result<Group<E>, Error>
pub fn from_x_coordinate(x_coordinate: Field<E>) -> Result<Group<E>, Error>
Attempts to recover an affine group element from a given x-coordinate field element. For safety, the resulting point is always enforced to be on the curve and in the correct subgroup.
§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 a new group from the (x, y)
affine coordinates.
pub fn from_xy_coordinates_unchecked(x: Field<E>, y: Field<E>) -> Group<E>
pub fn from_xy_coordinates_unchecked(x: Field<E>, y: Field<E>) -> Group<E>
Initializes a new group from the (x, y)
affine coordinates.
Note: The resulting point is not enforced to be on the curve or in the subgroup.
§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 in the affine coordinates of the group.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub fn to_xy_coordinates(&self) -> (Field<E>, Field<E>)
pub fn to_xy_coordinates(&self) -> (Field<E>, Field<E>)
Returns the x-coordinate and y-coordinate in the affine coordinates of the group.
§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 in the affine coordinates of the group.
§impl<E> Group<E>where
E: Environment,
impl<E> Group<E>where E: Environment,
pub const MONTGOMERY_A: Field<E> = _
pub const MONTGOMERY_A: Field<E> = _
The coefficient A for the Montgomery curve equation.
pub const MONTGOMERY_B: Field<E> = _
pub const MONTGOMERY_B: Field<E> = _
The coefficient B for the Montgomery curve equation.
pub fn new(group: <E as Environment>::Affine) -> Group<E>
pub fn new(group: <E as Environment>::Affine) -> Group<E>
Initializes a new group.
pub fn mul_by_cofactor(&self) -> Group<E>
pub fn mul_by_cofactor(&self) -> Group<E>
Returns self * COFACTOR
.
pub fn div_by_cofactor(&self) -> Group<E>
pub fn div_by_cofactor(&self) -> Group<E>
Returns self / COFACTOR
.
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 for Group<E>where
E: Environment,
impl<E> Add 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>)
Adds other
to self
.
§impl<E> AddAssign for Group<E>where
E: Environment,
impl<E> AddAssign for Group<E>where E: Environment,
§fn add_assign(&mut self, other: Group<E>)
fn add_assign(&mut self, other: Group<E>)
Adds other
to self
.
source§impl<E: Environment, I: IntegerType> Cast<Group<E>> for Integer<E, I>
impl<E: Environment, I: IntegerType> Cast<Group<E>> for Integer<E, I>
source§impl<E: Environment> CastLossy<Group<E>> for Boolean<E>
impl<E: Environment> CastLossy<Group<E>> for Boolean<E>
source§fn cast_lossy(&self) -> Group<E>
fn cast_lossy(&self) -> Group<E>
Casts a Boolean
to a Group
.
This is safe because casting from a boolean to any other type is always lossless.
If the boolean is true, the group element is the generator of the prime-order subgroup. If the boolean is false, the group element is the zero group element.
source§impl<E: Environment> CastLossy<Group<E>> for Field<E>
impl<E: Environment> CastLossy<Group<E>> for Field<E>
source§fn cast_lossy(&self) -> Group<E>
fn cast_lossy(&self) -> Group<E>
Casts a Field
to a Group
.
This operation attempts to recover the group element from the given field.
If the field is a valid x-coordinate, then the group element is returned. If the field is not a valid x-coordinate, then if the field is the one element, the generator of the prime-order subgroup is returned. Otherwise, Elligator-2 is applied to the field element to recover a group element.
source§impl<E: Environment, I: IntegerType> CastLossy<Group<E>> for Integer<E, I>
impl<E: Environment, I: IntegerType> CastLossy<Group<E>> for Integer<E, I>
source§fn cast_lossy(&self) -> Group<E>
fn cast_lossy(&self) -> Group<E>
Casts an Integer
to a Group
.
This operation converts the integer into a field element, and then attempts to recover
the group element. See the documentation of Field::cast_lossy
on the Group
type
for more details.
source§impl<E: Environment> CastLossy<Group<E>> for Scalar<E>
impl<E: Environment> CastLossy<Group<E>> for Scalar<E>
source§fn cast_lossy(&self) -> Group<E>
fn cast_lossy(&self) -> Group<E>
Casts a Scalar
to a Group
.
This operation converts the scalar into a field element, and then attempts to recover
the group element. See the documentation of Field::cast_lossy
on the Group
type
for more details.
§impl<E> Clone for Group<E>where
E: Clone + Environment,
<E as Environment>::Projective: Clone,
impl<E> Clone for Group<E>where E: Clone + Environment, <E as Environment>::Projective: Clone,
§impl<E> Debug for Group<E>where
E: Environment,
impl<E> Debug for Group<E>where E: Environment,
§impl<E> Deref for Group<E>where
E: Environment,
impl<E> Deref for Group<E>where E: Environment,
§type Target = <E as Environment>::Projective
type Target = <E as Environment>::Projective
§impl<'de, E> Deserialize<'de> for Group<E>where
E: Environment,
impl<'de, E> Deserialize<'de> for Group<E>where E: Environment,
§fn deserialize<D>(
deserializer: D
) -> Result<Group<E>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize<D>( deserializer: D ) -> Result<Group<E>, <D as Deserializer<'de>>::Error>where D: Deserializer<'de>,
Deserializes the group from a string or bytes.
§impl<E> Display for Group<E>where
E: Environment,
impl<E> Display for Group<E>where E: Environment,
§impl<E> Distribution<Group<E>> for Standardwhere
E: Environment,
impl<E> Distribution<Group<E>> for Standardwhere E: Environment,
§fn sample<R>(&self, rng: &mut R) -> Group<E>where
R: Rng + ?Sized,
fn sample<R>(&self, rng: &mut R) -> Group<E>where R: Rng + ?Sized,
T
, using rng
as the source of randomness.§impl<E> Double for Group<E>where
E: Environment,
impl<E> Double for Group<E>where E: Environment,
§impl<E> Equal for Group<E>where
E: Environment,
impl<E> Equal for Group<E>where E: Environment,
§impl<E> FromBits for Group<E>where
E: Environment,
impl<E> FromBits for Group<E>where E: Environment,
§impl<E> FromBytes for Group<E>where
E: Environment,
impl<E> FromBytes for Group<E>where E: Environment,
§impl<E> FromField for Group<E>where
E: Environment,
impl<E> FromField for Group<E>where E: Environment,
§impl<E> FromFields for Group<E>where
E: Environment,
impl<E> FromFields for Group<E>where E: Environment,
§impl<E> FromStr for Group<E>where
E: Environment,
impl<E> FromStr for Group<E>where E: Environment,
§impl<E> Hash for Group<E>where
E: Hash + Environment,
<E as Environment>::Projective: Hash,
impl<E> Hash for Group<E>where E: Hash + Environment, <E as Environment>::Projective: Hash,
§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<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> 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>)
Multiplies self
by other
.
§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>)
Multiplies self
by other
.
§impl<E> Neg for Group<E>where
E: Environment,
impl<E> Neg for Group<E>where E: Environment,
§impl<E> Parser for Group<E>where
E: Environment,
impl<E> Parser for Group<E>where E: Environment,
§impl<E> PartialEq for Group<E>where
E: PartialEq + Environment,
<E as Environment>::Projective: PartialEq,
impl<E> PartialEq for Group<E>where E: PartialEq + Environment, <E as Environment>::Projective: PartialEq,
§impl<E> Serialize for Group<E>where
E: Environment,
impl<E> Serialize for Group<E>where E: Environment,
§fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>( &self, serializer: S ) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where S: Serializer,
Serializes the group into a string or as bytes.
§impl<E> SizeInBits for Group<E>where
E: Environment,
impl<E> SizeInBits for Group<E>where E: Environment,
§fn size_in_bits() -> usize
fn size_in_bits() -> usize
Returns the group size in bits.
§impl<E> SizeInBytes for Group<E>where
E: Environment,
impl<E> SizeInBytes for Group<E>where E: Environment,
§fn size_in_bytes() -> usize
fn size_in_bytes() -> usize
Returns the group size in bytes.
§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 for Group<E>where
E: Environment,
impl<E> Sub 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>)
Subtracts other
from self
.
§impl<E> SubAssign for Group<E>where
E: Environment,
impl<E> SubAssign for Group<E>where E: Environment,
§fn sub_assign(&mut self, other: Group<E>)
fn sub_assign(&mut self, other: Group<E>)
Subtracts other
from self
.
§impl<'a, E> Sum<&'a Group<E>> for Group<E>where
E: Environment,
impl<'a, E> Sum<&'a Group<E>> for Group<E>where E: Environment,
§impl<E> Sum for Group<E>where
E: Environment,
impl<E> Sum for Group<E>where E: Environment,
§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 write_bits_le(&self, vec: &mut Vec<bool>)
fn write_bits_le(&self, vec: &mut Vec<bool>)
Outputs the little-endian bit representation of self.to_x_coordinate()
without trailing zeros.
§fn write_bits_be(&self, vec: &mut Vec<bool>)
fn write_bits_be(&self, vec: &mut Vec<bool>)
Outputs the big-endian bit representation of self.to_x_coordinate()
without leading zeros.
source§fn to_bits_le(&self) -> Vec<bool>
fn to_bits_le(&self) -> Vec<bool>
self
as a boolean array in little-endian order.source§fn to_bits_be(&self) -> Vec<bool>
fn to_bits_be(&self) -> Vec<bool>
self
as a boolean array in big-endian order.§impl<E> ToBytes for Group<E>where
E: Environment,
impl<E> ToBytes for Group<E>where E: Environment,
§impl<E> ToField for Group<E>where
E: Environment,
impl<E> ToField for Group<E>where E: Environment,
§impl<E> ToFields for Group<E>where
E: Environment,
impl<E> ToFields for Group<E>where E: Environment,
§impl<E> TypeName for Group<E>where
E: Environment,
impl<E> TypeName for Group<E>where E: Environment,
§impl<E> Visibility for Group<E>where
E: Environment,
impl<E> Visibility for Group<E>where E: Environment,
§impl<E> Zero for Group<E>where
E: Environment,
impl<E> Zero for Group<E>where E: Environment,
impl<E> Copy for Group<E>where E: Copy + Environment, <E as Environment>::Projective: Copy,
impl<E> Eq for Group<E>where E: Eq + Environment, <E as Environment>::Projective: Eq,
impl<E> GroupTrait<Scalar<E>> for Group<E>where E: Environment,
impl<E> StructuralEq for Group<E>where E: Environment,
impl<E> StructuralPartialEq for Group<E>where E: Environment,
Auto Trait Implementations§
impl<E> RefUnwindSafe for Group<E>where <E as Environment>::Projective: RefUnwindSafe,
impl<E> Send for Group<E>
impl<E> Sync for Group<E>
impl<E> Unpin for Group<E>where <E as Environment>::Projective: Unpin,
impl<E> UnwindSafe for Group<E>where <E as Environment>::Projective: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<'de, T> DeserializeExt<'de> for Twhere
T: DeserializeOwned,
impl<'de, T> DeserializeExt<'de> for Twhere T: DeserializeOwned,
fn take_from_value<D>( value: &mut Value, field: &str ) -> Result<T, <D as Deserializer<'de>>::Error>where D: Deserializer<'de>,
§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.