-
Attributes:
#[defines_primitive(#[u64])]
Return the larger of x
and y
Return the smaller of x
and y
Return the absolute value of x - y
Calculate x / y, but round up the result.
public fun divide_and_round_up(x: u64, y: u64): u64
Returns x * y / z with as little loss of precision as possible and avoid overflow
public fun multiple_and_divide(x: u64, y: u64, z: u64): u64
Return the value of a base raised to a power
Get a nearest lower integer Square Root for x
. Given that this
function can only operate with integers, it is impossible
to get perfect (or precise) integer square root for some numbers.
Example:
math::sqrt(9) => 3
math::sqrt(8) => 2 // the nearest lower square root is 4;
In integer math, one of the possible ways to get results with more precision is to use higher values or temporarily multiply the value by some bigger number. Ideally if this is a square of 10 or 100.
Example:
math::sqrt(8) => 2;
math::sqrt(8 * 10000) => 282;
// now we can use this value as if it was 2.82;
// but to get the actual result, this value needs
// to be divided by 100 (because sqrt(10000)).
math::sqrt(8 * 1000000) => 2828; // same as above, 2828 / 1000 (2.828)