LiquidityCalcs

implements calculation methods used for Fluid liquidity such as updated exchange prices, borrow rate, withdrawal / borrow limits, revenue amount.

FluidLiquidityCalcsError

error FluidLiquidityCalcsError(uint256 errorId_)

BorrowRateMaxCap

event BorrowRateMaxCap()

emitted if the calculated borrow rate surpassed max borrow rate (16 bits) and was capped at maximum value 65535

EXCHANGE_PRICES_PRECISION

uint256 EXCHANGE_PRICES_PRECISION

constants as from Liquidity variables.sol

SECONDS_PER_YEAR

uint256 SECONDS_PER_YEAR

Ignoring leap years

DEFAULT_EXPONENT_SIZE

uint256 DEFAULT_EXPONENT_SIZE

DEFAULT_EXPONENT_MASK

uint256 DEFAULT_EXPONENT_MASK

FOUR_DECIMALS

uint256 FOUR_DECIMALS

TWELVE_DECIMALS

uint256 TWELVE_DECIMALS

X14

uint256 X14

X15

uint256 X15

X16

uint256 X16

X18

uint256 X18

X24

uint256 X24

X33

uint256 X33

X64

uint256 X64

calcExchangePrices

function calcExchangePrices(uint256 exchangePricesAndConfig_) internal view returns (uint256 supplyExchangePrice_, uint256 borrowExchangePrice_)

calculates interest (exchange prices) for a token given its' exchangePricesAndConfig from storage.

Parameters

NameTypeDescription
exchangePricesAndConfig_uint256exchange prices and config packed uint256 read from storage

Return Values

NameTypeDescription
supplyExchangePrice_uint256updated supplyExchangePrice
borrowExchangePrice_uint256updated borrowExchangePrice

calcRevenue

function calcRevenue(uint256 totalAmounts_, uint256 exchangePricesAndConfig_, uint256 liquidityTokenBalance_) internal view returns (uint256 revenueAmount_)

_gets the revenueAmount_ for a token given its' totalAmounts and exchangePricesAndConfig from storage and the current balance of the Fluid liquidity contract for the token._

Parameters

NameTypeDescription
totalAmounts_uint256total amounts packed uint256 read from storage
exchangePricesAndConfig_uint256exchange prices and config packed uint256 read from storage
liquidityTokenBalance_uint256current balance of Liquidity contract (IERC20(token_).balanceOf(address(this)))

Return Values

NameTypeDescription
revenueAmount_uint256collectable revenue amount

calcWithdrawalLimitBeforeOperate

function calcWithdrawalLimitBeforeOperate(uint256 userSupplyData_, uint256 userSupply_) internal view returns (uint256 currentWithdrawalLimit_)

calculates withdrawal limit before an operate execution: amount of user supply that must stay supplied (not amount that can be withdrawn). i.e. if user has supplied 100m and can withdraw 5M, this method returns the 95M, not the withdrawable amount 5M

Parameters

NameTypeDescription
userSupplyData_uint256user supply data packed uint256 from storage
userSupply_uint256current user supply amount already extracted from userSupplyData_ and converted from BigMath

Return Values

NameTypeDescription
currentWithdrawalLimit_uint256current withdrawal limit updated for expansion since last interaction. returned value is in raw for with interest mode, normal amount for interest free mode!

calcWithdrawalLimitAfterOperate

function calcWithdrawalLimitAfterOperate(uint256 userSupplyData_, uint256 userSupply_, uint256 newWithdrawalLimit_) internal pure returns (uint256)

calculates withdrawal limit after an operate execution: amount of user supply that must stay supplied (not amount that can be withdrawn). i.e. if user has supplied 100m and can withdraw 5M, this method returns the 95M, not the withdrawable amount 5M

Parameters

NameTypeDescription
userSupplyData_uint256user supply data packed uint256 from storage
userSupply_uint256current user supply amount already extracted from userSupplyData_ and added / subtracted with the executed operate amount
newWithdrawalLimit_uint256current withdrawal limit updated for expansion since last interaction, result from calcWithdrawalLimitBeforeOperate

Return Values

NameTypeDescription
0uint256withdrawalLimit_ updated withdrawal limit that should be written to storage. returned value is in raw for with interest mode, normal amount for interest free mode!

calcBorrowLimitBeforeOperate

function calcBorrowLimitBeforeOperate(uint256 userBorrowData_, uint256 userBorrow_) internal view returns (uint256 currentBorrowLimit_)

calculates borrow limit before an operate execution: total amount user borrow can reach (not borrowable amount in current operation). i.e. if user has borrowed 50M and can still borrow 5M, this method returns the total 55M, not the borrowable amount 5M

Parameters

NameTypeDescription
userBorrowData_uint256user borrow data packed uint256 from storage
userBorrow_uint256current user borrow amount already extracted from userBorrowData_

Return Values

NameTypeDescription
currentBorrowLimit_uint256current borrow limit updated for expansion since last interaction. returned value is in raw for with interest mode, normal amount for interest free mode!

calcBorrowLimitAfterOperate

function calcBorrowLimitAfterOperate(uint256 userBorrowData_, uint256 userBorrow_, uint256 newBorrowLimit_) internal pure returns (uint256 borrowLimit_)

calculates borrow limit after an operate execution: total amount user borrow can reach (not borrowable amount in current operation). i.e. if user has borrowed 50M and can still borrow 5M, this method returns the total 55M, not the borrowable amount 5M

Parameters

NameTypeDescription
userBorrowData_uint256user borrow data packed uint256 from storage
userBorrow_uint256current user borrow amount already extracted from userBorrowData_ and added / subtracted with the executed operate amount
newBorrowLimit_uint256current borrow limit updated for expansion since last interaction, result from calcBorrowLimitBeforeOperate

Return Values

NameTypeDescription
borrowLimit_uint256updated borrow limit that should be written to storage. returned value is in raw for with interest mode, normal amount for interest free mode!

calcBorrowRateFromUtilization

function calcBorrowRateFromUtilization(uint256 rateData_, uint256 utilization_) internal returns (uint256 rate_)

Calculates new borrow rate from utilization for a token

Parameters

NameTypeDescription
rateData_uint256rate data packed uint256 from storage for the token
utilization_uint256totalBorrow / totalSupply. 1e4 = 100% utilization

Return Values

NameTypeDescription
rate_uint256rate for that particular token in 1e2 precision (e.g. 5% rate = 500)

calcRateV1

function calcRateV1(uint256 rateData_, uint256 utilization_) internal pure returns (uint256 rate_)

calculates the borrow rate based on utilization for rate data version 1 (with one kink) in 1e2 precision

Parameters

NameTypeDescription
rateData_uint256rate data packed uint256 from storage for the token
utilization_uint256in 1e2 (100% = 1e4)

Return Values

NameTypeDescription
rate_uint256rate in 1e2 precision

calcRateV2

function calcRateV2(uint256 rateData_, uint256 utilization_) internal pure returns (uint256 rate_)

calculates the borrow rate based on utilization for rate data version 2 (with two kinks) in 1e4 precision

Parameters

NameTypeDescription
rateData_uint256rate data packed uint256 from storage for the token
utilization_uint256in 1e2 (100% = 1e4)

Return Values

NameTypeDescription
rate_uint256rate in 1e4 precision

getTotalSupply

function getTotalSupply(uint256 totalAmounts_, uint256 supplyExchangePrice_) internal pure returns (uint256 totalSupply_)

_reads the total supply out of Liquidity packed storage totalAmounts_forsupplyExchangePrice**

getTotalBorrow

function getTotalBorrow(uint256 totalAmounts_, uint256 borrowExchangePrice_) internal pure returns (uint256 totalBorrow_)

_reads the total borrow out of Liquidity packed storage totalAmounts_forborrowExchangePrice**