pub struct Fp(/* private fields */);
Expand description
Fp
represents an element of the base field Fq
of the BLS12-381 elliptic
curve
§Serialization:
- The 48 bytes represent the big-endian encoding of an element in the
field
Fp
. The value is serialized as a big-endian integer.
Implementations§
Source§impl Fp
impl Fp
pub fn from_bytes(bytes: BytesN<FP_SERIALIZED_SIZE>) -> Self
pub fn to_bytes(&self) -> BytesN<FP_SERIALIZED_SIZE>
pub fn as_bytes(&self) -> &BytesN<FP_SERIALIZED_SIZE>
pub fn to_array(&self) -> [u8; 48]
pub fn from_array(env: &Env, array: &[u8; 48]) -> Self
pub fn as_val(&self) -> &Val
pub fn to_val(&self) -> Val
pub fn as_object(&self) -> &BytesObject
pub fn to_object(&self) -> BytesObject
Source§impl Fp
impl Fp
pub fn env(&self) -> &Env
Sourcepub fn map_to_g1(&self) -> G1Affine
pub fn map_to_g1(&self) -> G1Affine
Maps this Fp
element to a G1Affine
point using the simplified SWU
mapping.
Warning
The resulting point is on the curve but may not be in the prime-order subgroup (operations like pairing may fail). To ensure the point is in the prime-order subgroup, cofactor clearing must be performed on the output.For applications requiring a point directly in the prime-order subgroup, consider using
hash_to_g1
, which handles subgroup checks and cofactor clearing internally.
Trait Implementations§
Source§impl SorobanArbitrary for Fp
Available on crate feature testutils
only.
impl SorobanArbitrary for Fp
Available on crate feature
testutils
only.Source§type Prototype = ArbitraryFp
type Prototype = ArbitraryFp
A type that implements
Arbitrary
and can be converted to this
SorobanArbitrary
type.impl Eq for Fp
Auto Trait Implementations§
impl Freeze for Fp
impl !RefUnwindSafe for Fp
impl !Send for Fp
impl !Sync for Fp
impl Unpin for Fp
impl !UnwindSafe for Fp
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T, U, V, W, E, C> Compare<(T, U, V, W)> for C
impl<T, U, V, W, E, C> Compare<(T, U, V, W)> for C
type Error = E
fn compare( &self, a: &(T, U, V, W), b: &(T, U, V, W), ) -> Result<Ordering, <C as Compare<(T, U, V, W)>>::Error>
Source§impl<T, U, V, W, X, E, C> Compare<(T, U, V, W, X)> for C
impl<T, U, V, W, X, E, C> Compare<(T, U, V, W, X)> for C
type Error = E
fn compare( &self, a: &(T, U, V, W, X), b: &(T, U, V, W, X), ) -> Result<Ordering, <C as Compare<(T, U, V, W, X)>>::Error>
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<E, T, U> FromVal<E, T> for Uwhere
E: Env,
U: TryFromVal<E, T>,
impl<E, T, U> FromVal<E, T> for Uwhere
E: Env,
U: TryFromVal<E, T>,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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