mulDiv#
Fully qualified name: carb::math::mulDiv
Defined in carb/math/MulDiv.h
- 
template<class RoundPolicy>
 cpp::optional<uint64_t> carb::math::mulDiv(
- RoundPolicy round,
- uint64_t num,
- uint64_t multiplier,
- uint64_t divisor,
- Multiplies two 64-bit unsigned integers and then divides the 128-bit result by a third 64-bit unsigned integer. - Typically multiplying - num*- multipliercan result in overflowing a 64-bit value. This function uses a 128-bit temporary value for the multiplication operation, and then divides it by a 64-bit value. Effectively performs:- uint128_t temp = uint128_t(num) * multiplier; if (!divisor || (temp >> 64) >= divisor) return cpp::nullopt; // overflow or divide by zero return uint64_t(round(temp / divisor)); - If the result will not fit in a 64-bit value, or - divisoris zero,- carb::cpp::nulloptis returned to indicate the math error.- Parameters:
- round – The rounding policy to use. See round_toward_zero, round_away_from_zero and round_nearest_neighbor. 
- num – The multiplicand. 
- multiplier – The multiplier, multiplied with - numproduces a 128-bit value.
- divisor – The divisor, used to divide the 128-bit product of - numX- multiplier.
 
- Returns:
- A carb::cpp::optional containing the 64-bit result of the operation. If - divisoris zero, or the result would not fit in a 64-bit value,- carb::cpp::nulloptis returned instead.