Exponential
Exponentialβ
Exp is a struct which stores decimals with a fixed precision of 18 decimal places.
Thus, if we wanted to store the 5.1, mantissa would store 5.1e18. That is:
Exp({mantissa: 5100000000000000000})
.
Legacy contract for compatibility reasons with existing contracts that still use MathError
getExpβ
function getExp(uint256 num, uint256 denom) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Creates an exponential from numerator and denominator values.
Note: Returns an error if (num
* 10e18) > MAX_INT,
or if denom
is zero.
addExpβ
function addExp(struct ExponentialNoError.Exp a, struct ExponentialNoError.Exp b) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Adds two exponentials, returning a new exponential.
subExpβ
function subExp(struct ExponentialNoError.Exp a, struct ExponentialNoError.Exp b) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Subtracts two exponentials, returning a new exponential.
mulScalarβ
function mulScalar(struct ExponentialNoError.Exp a, uint256 scalar) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Multiply an Exp by a scalar, returning a new Exp.
mulScalarTruncateβ
function mulScalarTruncate(struct ExponentialNoError.Exp a, uint256 scalar) internal pure returns (enum CarefulMath.MathError, uint256)
Multiply an Exp by a scalar, then truncate to return an unsigned integer.
mulScalarTruncateAddUIntβ
function mulScalarTruncateAddUInt(struct ExponentialNoError.Exp a, uint256 scalar, uint256 addend) internal pure returns (enum CarefulMath.MathError, uint256)
Multiply an Exp by a scalar, truncate, then add an to an unsigned integer, returning an unsigned integer.
divScalarβ
function divScalar(struct ExponentialNoError.Exp a, uint256 scalar) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Divide an Exp by a scalar, returning a new Exp.
divScalarByExpβ
function divScalarByExp(uint256 scalar, struct ExponentialNoError.Exp divisor) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Divide a scalar by an Exp, returning a new Exp.
divScalarByExpTruncateβ
function divScalarByExpTruncate(uint256 scalar, struct ExponentialNoError.Exp divisor) internal pure returns (enum CarefulMath.MathError, uint256)
Divide a scalar by an Exp, then truncate to return an unsigned integer.
mulExpβ
function mulExp(struct ExponentialNoError.Exp a, struct ExponentialNoError.Exp b) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Multiplies two exponentials, returning a new exponential.
mulExpβ
function mulExp(uint256 a, uint256 b) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Multiplies two exponentials given their mantissas, returning a new exponential.
mulExp3β
function mulExp3(struct ExponentialNoError.Exp a, struct ExponentialNoError.Exp b, struct ExponentialNoError.Exp c) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Multiplies three exponentials, returning a new exponential.
divExpβ
function divExp(struct ExponentialNoError.Exp a, struct ExponentialNoError.Exp b) internal pure returns (enum CarefulMath.MathError, struct ExponentialNoError.Exp)
Divides two exponentials, returning a new exponential. (a/scale) / (b/scale) = (a/scale) * (scale/b) = a/b, which we can scale as an Exp by calling getExp(a.mantissa, b.mantissa)