Skip to main content

Module deepbook::math

Constants

const EUnderflow: u64 = 1;

scaling setting for float

const FLOAT_SCALING: u64 = 1000000000;

const FLOAT_SCALING_U128: u128 = 1000000000;

Function unsafe_mul

public(package) fun unsafe_mul(x: u64, y: u64): u64
Click to open
Implementation
public(package) fun unsafe_mul(x: u64, y: u64): u64 {
    let (_, result) = unsafe_mul_round(x, y);
    result
}

Function unsafe_mul_round

public(package) fun unsafe_mul_round(x: u64, y: u64): (bool, u64)
Click to open
Implementation
public(package) fun unsafe_mul_round(x: u64, y: u64): (bool, u64) {
    let x = x as u128;
    let y = y as u128;
    let mut is_round_down = true;
    if ((x * y) % FLOAT_SCALING_U128 == 0) is_round_down = false;
    (is_round_down, (x * y / FLOAT_SCALING_U128) as u64)
}

Function mul

public fun mul(x: u64, y: u64): u64
Click to open
Implementation
public fun mul(x: u64, y: u64): u64 {
    let (_, result) = unsafe_mul_round(x, y);
    assert!(result > 0, EUnderflow);
    result
}

Function mul_round

public fun mul_round(x: u64, y: u64): (bool, u64)
Click to open
Implementation
public fun mul_round(x: u64, y: u64): (bool, u64) {
    let (is_round_down, result) = unsafe_mul_round(x, y);
    assert!(result > 0, EUnderflow);
    (is_round_down, result)
}

Function unsafe_div

public(package) fun unsafe_div(x: u64, y: u64): u64
Click to open
Implementation
public(package) fun unsafe_div(x: u64, y: u64): u64 {
    let (_, result) = unsafe_div_round(x, y);
    result
}

Function unsafe_div_round

public(package) fun unsafe_div_round(x: u64, y: u64): (bool, u64)
Click to open
Implementation
public(package) fun unsafe_div_round(x: u64, y: u64): (bool, u64) {
    let x = x as u128;
    let y = y as u128;
    let mut is_round_down = true;
    if ((x * (FLOAT_SCALING as u128) % y) == 0) is_round_down = false;
    (is_round_down, (x * (FLOAT_SCALING as u128) / y) as u64)
}

Function div_round

public fun div_round(x: u64, y: u64): (bool, u64)
Click to open
Implementation
public fun div_round(x: u64, y: u64): (bool, u64) {
    let (is_round_down, result) = unsafe_div_round(x, y);
    assert!(result > 0, EUnderflow);
    (is_round_down, result)
}

Function count_leading_zeros

public(package) fun count_leading_zeros(x: u128): u8
Click to open
Implementation
public(package) fun count_leading_zeros(mut x: u128): u8 {
    if (x == 0) {
        128
    } else {
        let mut n: u8 = 0;
        if (x & 0xFFFFFFFFFFFFFFFF0000000000000000 == 0) {
            // x's higher 64 is all zero, shift the lower part over
            x = x << 64;
            n = n + 64;
        };
        if (x & 0xFFFFFFFF000000000000000000000000 == 0) {
            // x's higher 32 is all zero, shift the lower part over
            x = x << 32;
            n = n + 32;
        };
        if (x & 0xFFFF0000000000000000000000000000 == 0) {
            // x's higher 16 is all zero, shift the lower part over
            x = x << 16;
            n = n + 16;
        };
        if (x & 0xFF000000000000000000000000000000 == 0) {
            // x's higher 8 is all zero, shift the lower part over
            x = x << 8;
            n = n + 8;
        };
        if (x & 0xF0000000000000000000000000000000 == 0) {
            // x's higher 4 is all zero, shift the lower part over
            x = x << 4;
            n = n + 4;
        };
        if (x & 0xC0000000000000000000000000000000 == 0) {
            // x's higher 2 is all zero, shift the lower part over
            x = x << 2;
            n = n + 2;
        };
        if (x & 0x80000000000000000000000000000000 == 0) {
            n = n + 1;
        };
        n
    }
}