multiversx_sc::types

Struct BigFloat

Source
pub struct BigFloat<M: ManagedTypeApi> { /* private fields */ }

Implementations§

Source§

impl<M: ManagedTypeApi> BigFloat<M>

Source

pub fn neg(&self) -> Self

Source

pub fn abs(&self) -> Self

Source

pub fn from_big_int(big_int: &BigInt<M>) -> Self

Source

pub fn from_big_uint(big_uint: &BigUint<M>) -> Self

Source

pub fn from_parts( integral_part_value: i32, fractional_part_value: i32, exponent_value: i32, ) -> Self

Source

pub fn from_frac(numerator_value: i64, denominator_value: i64) -> Self

Source

pub fn from_sci(significand_value: i64, exponent_value: i32) -> Self

Source

pub fn trunc(&self) -> BigInt<M>

Source

pub fn floor(&self) -> BigInt<M>

Source

pub fn ceil(&self) -> BigInt<M>

Source

pub fn to_fixed_point(&self, denominator: &BigFloat<M>) -> BigInt<M>

Source

pub fn to_managed_decimal_signed<T: Decimals>( &self, decimals: T, ) -> ManagedDecimalSigned<M, T>

Source

pub fn ln(&self) -> Option<Self>

Computes the natural logarithm of the current number.

The error is around +/- 0.00006, for all inputs.

Will return None for zero or negative numbers.

Source

pub fn zero() -> Self

Source

pub fn from_buffer(managed_buffer: &ManagedBuffer<M>) -> Self

Source

pub fn to_buffer(&self) -> ManagedBuffer<M>

Source

pub unsafe fn new_uninit() -> Self

Creates a new object, without initializing it.

§Safety

The value needs to be initialized after creation, otherwise the VM will halt the first time the value is attempted to be read.

Source§

impl<M: ManagedTypeApi> BigFloat<M>

Source

pub fn sqrt(&self) -> Self

Source

pub fn pow(&self, exp: i32) -> Self

Source

pub fn sign(&self) -> Sign

Returns the sign of the BigFloat as a Sign.

Source

pub fn magnitude(&self) -> BigFloat<M>

Returns the magnitude of the BigFloat

Source

pub fn to_parts(self) -> (Sign, BigFloat<M>)

Convert this BigFloat into its Sign and its magnitude, the reverse of BigInt::from_biguint.

Source§

impl<M: ManagedTypeApi> BigFloat<M>

Source

pub fn to_f64(&self) -> f64

Warning: cannot be used in contracts. It is only meant to simplify certain tests.

It might also not be optimal with respect to precision.

Source§

impl<M: ManagedTypeApi> BigFloat<M>

Source

pub fn is_close(&self, other: &Self, abs_tolerance: &Self) -> bool

Trait Implementations§

Source§

impl<'a, 'b, M: ManagedTypeApi> Add<&'b BigFloat<M>> for &'a BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the + operator.
Source§

fn add(self, other: &BigFloat<M>) -> BigFloat<M>

Performs the + operation. Read more
Source§

impl<M: ManagedTypeApi> Add for BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the + operator.
Source§

fn add(self, other: BigFloat<M>) -> BigFloat<M>

Performs the + operation. Read more
Source§

impl<M: ManagedTypeApi> AddAssign<&BigFloat<M>> for BigFloat<M>

Source§

fn add_assign(&mut self, other: &BigFloat<M>)

Performs the += operation. Read more
Source§

impl<M: ManagedTypeApi> AddAssign for BigFloat<M>

Source§

fn add_assign(&mut self, other: Self)

Performs the += operation. Read more
Source§

impl<M: ManagedTypeApi> Clone for BigFloat<M>

Source§

fn clone(&self) -> Self

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

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

Performs copy-assignment from source. Read more
Source§

impl<M: Debug + ManagedTypeApi> Debug for BigFloat<M>

Source§

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

Formats the value using the given formatter. Read more
Source§

impl<'a, 'b, M: ManagedTypeApi> Div<&'b BigFloat<M>> for &'a BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the / operator.
Source§

fn div(self, other: &BigFloat<M>) -> BigFloat<M>

Performs the / operation. Read more
Source§

impl<M: ManagedTypeApi> Div for BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the / operator.
Source§

fn div(self, other: BigFloat<M>) -> BigFloat<M>

Performs the / operation. Read more
Source§

impl<M: ManagedTypeApi> DivAssign<&BigFloat<M>> for BigFloat<M>

Source§

fn div_assign(&mut self, other: &BigFloat<M>)

Performs the /= operation. Read more
Source§

impl<M: ManagedTypeApi> DivAssign for BigFloat<M>

Source§

fn div_assign(&mut self, other: Self)

Performs the /= operation. Read more
Source§

impl<M: ManagedTypeApi, const DECIMALS: NumDecimals> From<&BigFloat<M>> for ManagedDecimalSigned<M, ConstDecimals<DECIMALS>>

Source§

fn from(value: &BigFloat<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<&BigInt<M>> for BigFloat<M>

Source§

fn from(item: &BigInt<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<&BigUint<M>> for BigFloat<M>

Source§

fn from(item: &BigUint<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<&ManagedBuffer<M>> for BigFloat<M>

Source§

fn from(item: &ManagedBuffer<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi, const DECIMALS: NumDecimals> From<BigFloat<M>> for ManagedDecimalSigned<M, ConstDecimals<DECIMALS>>

Source§

fn from(value: BigFloat<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<BigInt<M>> for BigFloat<M>

Source§

fn from(item: BigInt<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<BigUint<M>> for BigFloat<M>

Source§

fn from(item: BigUint<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<ManagedBuffer<M>> for BigFloat<M>

Source§

fn from(item: ManagedBuffer<M>) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<f32> for BigFloat<M>

Source§

fn from(x: f32) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<f64> for BigFloat<M>

Source§

fn from(x: f64) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<i16> for BigFloat<M>

Source§

fn from(value: i16) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<i32> for BigFloat<M>

Source§

fn from(value: i32) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<i64> for BigFloat<M>

Source§

fn from(value: i64) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<i8> for BigFloat<M>

Source§

fn from(value: i8) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> From<isize> for BigFloat<M>

Source§

fn from(value: isize) -> Self

Converts to this type from the input type.
Source§

impl<M: ManagedTypeApi> ManagedType<M> for BigFloat<M>

Source§

type OwnHandle = <M as HandleTypeInfo>::BigFloatHandle

Source§

fn get_handle(&self) -> M::BigFloatHandle

Source§

unsafe fn forget_into_handle(self) -> Self::OwnHandle

Forgets current object (does not run destructor), but extracts the handle. Read more
Source§

fn transmute_from_handle_ref(handle_ref: &M::BigFloatHandle) -> &Self

Implement carefully, since the underlying transmutation is an unsafe operation. For types that wrap a handle to some VM-managed data, make sure the type only contains the handle (plus ZSTs if necessary). For types that just wrap another managed type it is easier, call for the wrapped object.
Source§

fn transmute_from_handle_ref_mut( handle_ref: &mut M::BigFloatHandle, ) -> &mut Self

Source§

fn get_raw_handle(&self) -> RawHandle

Source§

fn as_ref(&self) -> ManagedRef<'_, M, Self>

Source§

impl<'a, 'b, M: ManagedTypeApi> Mul<&'b BigFloat<M>> for &'a BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the * operator.
Source§

fn mul(self, other: &BigFloat<M>) -> BigFloat<M>

Performs the * operation. Read more
Source§

impl<M: ManagedTypeApi> Mul for BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the * operator.
Source§

fn mul(self, other: BigFloat<M>) -> BigFloat<M>

Performs the * operation. Read more
Source§

impl<M: ManagedTypeApi> MulAssign<&BigFloat<M>> for BigFloat<M>

Source§

fn mul_assign(&mut self, other: &BigFloat<M>)

Performs the *= operation. Read more
Source§

impl<M: ManagedTypeApi> MulAssign for BigFloat<M>

Source§

fn mul_assign(&mut self, other: Self)

Performs the *= operation. Read more
Source§

impl<M: ManagedTypeApi> Neg for BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the - operator.
Source§

fn neg(self) -> Self::Output

Performs the unary - operation. Read more
Source§

impl<M: ManagedTypeApi> NestedDecode for BigFloat<M>

Source§

fn dep_decode_or_handle_err<I, H>( input: &mut I, h: H, ) -> Result<Self, H::HandledErr>

Version of dep_decode that can handle errors as soon as they occur. For instance in can exit immediately and make sure that if it returns, it is a success. By not deferring error handling, this can lead to somewhat smaller bytecode.
Source§

fn dep_decode<I>(input: &mut I) -> Result<Self, DecodeError>

Attempt to deserialise the value from input, using the format of an object nested inside another structure. In case of success returns the deserialized value and the number of bytes consumed during the operation.
Source§

impl<M: ManagedTypeApi> NestedEncode for BigFloat<M>

Source§

fn dep_encode_or_handle_err<O, H>( &self, dest: &mut O, h: H, ) -> Result<(), H::HandledErr>

Version of dep_encode that can handle errors as soon as they occur. For instance in can exit immediately and make sure that if it returns, it is a success. By not deferring error handling, this can lead to somewhat smaller bytecode.
Source§

fn dep_encode<O>(&self, dest: &mut O) -> Result<(), EncodeError>

NestedEncode to output, using the format of an object nested inside another structure. Does not provide compact version.
Source§

impl<M: ManagedTypeApi> Ord for BigFloat<M>

Source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<M: ManagedTypeApi> PartialEq<BigInt<M>> for BigFloat<M>

Source§

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

impl<M: ManagedTypeApi> PartialEq<i64> for BigFloat<M>

Source§

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

impl<M: ManagedTypeApi> PartialEq for BigFloat<M>

Source§

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

impl<M: ManagedTypeApi> PartialOrd<BigInt<M>> for BigFloat<M>

Source§

fn partial_cmp(&self, other: &BigInt<M>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<M: ManagedTypeApi> PartialOrd<i64> for BigFloat<M>

Source§

fn partial_cmp(&self, other: &i64) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<M: ManagedTypeApi> PartialOrd for BigFloat<M>

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<'a, 'b, M: ManagedTypeApi> Sub<&'b BigFloat<M>> for &'a BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the - operator.
Source§

fn sub(self, other: &BigFloat<M>) -> BigFloat<M>

Performs the - operation. Read more
Source§

impl<M: ManagedTypeApi> Sub for BigFloat<M>

Source§

type Output = BigFloat<M>

The resulting type after applying the - operator.
Source§

fn sub(self, other: BigFloat<M>) -> BigFloat<M>

Performs the - operation. Read more
Source§

impl<M: ManagedTypeApi> SubAssign<&BigFloat<M>> for BigFloat<M>

Source§

fn sub_assign(&mut self, other: &BigFloat<M>)

Performs the -= operation. Read more
Source§

impl<M: ManagedTypeApi> SubAssign for BigFloat<M>

Source§

fn sub_assign(&mut self, other: Self)

Performs the -= operation. Read more
Source§

impl<M: ManagedTypeApi> TopDecode for BigFloat<M>

Source§

fn top_decode_or_handle_err<I, H>(input: I, h: H) -> Result<Self, H::HandledErr>

Version of top_decode that can handle errors as soon as they occur. For instance it can exit immediately and make sure that if it returns, it is a success. By not deferring error handling, this can lead to somewhat smaller bytecode.
Source§

fn top_decode<I>(input: I) -> Result<Self, DecodeError>
where I: TopDecodeInput,

Attempt to deserialize the value from input.
Source§

impl<M: ManagedTypeApi> TopEncode for BigFloat<M>

Source§

fn top_encode_or_handle_err<O, H>( &self, output: O, h: H, ) -> Result<(), H::HandledErr>

Version of top_encode that can handle errors as soon as they occur. For instance in can exit immediately and make sure that if it returns, it is a success. By not deferring error handling, this can lead to somewhat smaller bytecode.
Source§

fn top_encode<O>(&self, output: O) -> Result<(), EncodeError>
where O: TopEncodeOutput,

Attempt to serialize the value to ouput.
Source§

impl<M: ManagedTypeApi> TryStaticCast for BigFloat<M>

Source§

fn type_eq<U>() -> bool
where U: TryStaticCast,

Source§

fn try_cast<U>(self) -> Option<U>
where U: TryStaticCast,

Source§

fn try_cast_ref<U>(&self) -> Option<&U>
where U: TryStaticCast,

Source§

impl<M: ManagedTypeApi> TypeAbi for BigFloat<M>

Source§

type Unmanaged = f64

Source§

fn type_name() -> String

Source§

fn type_names() -> TypeNames

Source§

fn type_name_rust() -> TypeName

Source§

fn provide_type_descriptions<TDC: TypeDescriptionContainer>( accumulator: &mut TDC, )

A type can provide more than its own name. For instance, a struct can also provide the descriptions of the type of its fields. TypeAbi doesn’t care for the exact accumulator type, which is abstracted by the TypeDescriptionContainer trait.
Source§

impl<M: ManagedTypeApi> Eq for BigFloat<M>

Source§

impl<M> TypeAbiFrom<&BigFloat<M>> for BigFloat<M>
where M: ManagedTypeApi,

Source§

impl<M> TypeAbiFrom<BigFloat<M>> for BigFloat<M>
where M: ManagedTypeApi,

Source§

impl<M> TypeAbiFrom<BigFloat<M>> for f64
where M: ManagedTypeApi,

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

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> SCCodec for T
where T: TopEncode,

Source§

fn fmt<F>(&self, f: &mut F)

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> TopDecodeMulti for T
where T: TopDecode,

Source§

const IS_SINGLE_VALUE: bool = true

Used to optimize single value loading of endpoint arguments.
Source§

fn multi_decode_or_handle_err<I, H>( input: &mut I, h: H, ) -> Result<T, <H as DecodeErrorHandler>::HandledErr>

Source§

fn multi_decode<I>(input: &mut I) -> Result<Self, DecodeError>

Source§

impl<T> TopDecodeMultiLength for T
where T: TopEncode + TopDecode,

Source§

const LEN: usize = 1usize

Source§

fn get_len() -> usize

Source§

impl<T> TopEncodeMulti for T
where T: TopEncode,

Source§

fn multi_encode_or_handle_err<O, H>( &self, output: &mut O, h: H, ) -> Result<(), <H as EncodeErrorHandler>::HandledErr>

Version of top_encode that can handle errors as soon as they occur. For instance in can exit immediately and make sure that if it returns, it is a success. By not deferring error handling, this can lead to somewhat smaller bytecode.
Source§

fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>

Attempt to serialize the value to ouput.
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.
Source§

impl<O, T> ProxyArg<O> for T
where O: TypeAbiFrom<T>, T: TopEncodeMulti,