Module std::uq64_64
Defines an unsigned, fixed-point numeric type with a 64-bit integer part and a 64-bit fractional part. The notation
uq64_64UQ64_64q indicates it a fixed-point
number. The u prefix indicates it is unsigned. The 64_64 suffix indicates the number of
bits, where the first number indicates the number of bits in the integer part, and the second
the number of bits in the fractional part--in this case 64 bits for each.
- Struct UQ64_64
- Constants
- Function from_quotient
- Function from_int
- Function add
- Function sub
- Function mul
- Function div
- Function to_int
- Function int_mul
- Function int_div
- Function le
- Function lt
- Function ge
- Function gt
- Function to_raw
- Function from_raw
Struct UQ64_64
A fixed-point numeric type with 64 integer bits and 64 fractional bits, represented by an underlying 128 bit value. This is a binary representation, so decimal values may not be exactly representable, but it provides more than 19 decimal digits of precision both before and after the decimal point (38 digits total).
public struct UQ64_64 has copy, drop, store
Fields
- 
0: u128
Constants
#[error]
const EDenominator: vector<u8> = b"Quotient specified with a zero denominator";
#[error]
const EQuotientTooSmall: vector<u8> = b"Quotient specified is too small, and is outside of the supported range";
#[error]
const EQuotientTooLarge: vector<u8> = b"Quotient specified is too large, and is outside of the supported range";
#[error]
const EOverflow: vector<u8> = b"Overflow from an arithmetic operation";
#[error]
const EDivisionByZero: vector<u8> = b"Division by zero";
The total number of bits in the fixed-point number. Used in
macroconst TOTAL_BITS: u8 = 128;
The number of fractional bits in the fixed-point number. Used in
macroconst FRACTIONAL_BITS: u8 = 64;
Function from_quotient
Create a fixed-point value from a quotient specified by its numerator and denominator.
from_quotientfrom_intfrom_rawpublic fun from_quotient(numerator: u128, denominator: u128): std::uq64_64::UQ64_64
Implementation
public fun from_quotient(numerator: u128, denominator: u128): UQ64_64 {
    UQ64_64(
        std::macros::uq_from_quotient!<u128, u256>(
            numerator,
            denominator,
            std::u128::max_value!(),
            TOTAL_BITS,
            FRACTIONAL_BITS,
            abort EDenominator,
            abort EQuotientTooSmall,
            abort EQuotientTooLarge,
        ),
    )
}
Function from_int
Create a fixed-point value from an integer.
from_intfrom_quotientfrom_rawpublic fun from_int(integer: u64): std::uq64_64::UQ64_64
Implementation
public fun from_int(integer: u64): UQ64_64 {
    UQ64_64(std::macros::uq_from_int!(integer, FRACTIONAL_BITS))
}
Function add
Add two fixed-point numbers, a + b.
Aborts if the sum overflows.
public fun add(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): std::uq64_64::UQ64_64
Implementation
public fun add(a: UQ64_64, b: UQ64_64): UQ64_64 {
    UQ64_64(std::macros::uq_add!<u128, u256>(a.0, b.0, std::u128::max_value!(), abort EOverflow))
}
Function sub
Subtract two fixed-point numbers, a - b.
Aborts if a < b.
public fun sub(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): std::uq64_64::UQ64_64
Function mul
Multiply two fixed-point numbers, truncating any fractional part of the product. Aborts if the product overflows.
public fun mul(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): std::uq64_64::UQ64_64
Function div
Divide two fixed-point numbers, truncating any fractional part of the quotient. Aborts if the divisor is zero. Aborts if the quotient overflows.
public fun div(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): std::uq64_64::UQ64_64
Function to_int
Convert a fixed-point number to an integer, truncating any fractional part.
public fun to_int(a: std::uq64_64::UQ64_64): u64
Implementation
public fun to_int(a: UQ64_64): u64 {
    std::macros::uq_to_int!(a.0, FRACTIONAL_BITS)
}
Function int_mul
Multiply a
u128public fun int_mul(val: u128, multiplier: std::uq64_64::UQ64_64): u128
Implementation
public fun int_mul(val: u128, multiplier: UQ64_64): u128 {
    std::macros::uq_int_mul!<u128, u256>(
        val,
        multiplier.0,
        std::u128::max_value!(),
        FRACTIONAL_BITS,
        abort EOverflow,
    )
}
Function int_div
Divide a
u128public fun int_div(val: u128, divisor: std::uq64_64::UQ64_64): u128
Implementation
public fun int_div(val: u128, divisor: UQ64_64): u128 {
    std::macros::uq_int_div!<u128, u256>(
        val,
        divisor.0,
        std::u128::max_value!(),
        FRACTIONAL_BITS,
        abort EDivisionByZero,
        abort EOverflow,
    )
}
Function le
Less than or equal to. Returns
truea <= a.
public fun le(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): bool
Function lt
Less than. Returns
truea < b.
public fun lt(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): bool
Function ge
Greater than or equal to. Returns
truea >= b.
public fun ge(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): bool
Function gt
Greater than. Returns
truea > b.
public fun gt(a: std::uq64_64::UQ64_64, b: std::uq64_64::UQ64_64): bool
Function to_raw
Accessor for the raw u128 value. Can be paired with
from_rawpublic fun to_raw(a: std::uq64_64::UQ64_64): u128
Function from_raw
Accessor for the raw u128 value. Can be paired with
to_rawpublic fun from_raw(raw_value: u128): std::uq64_64::UQ64_64