Skip to content

LiquidityCalcs ​

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

FluidLiquidityCalcsError ​

solidity
error FluidLiquidityCalcsError(uint256 errorId_)

BorrowRateMaxCap ​

solidity
event BorrowRateMaxCap()

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

EXCHANGE_PRICES_PRECISION ​

solidity
uint256 EXCHANGE_PRICES_PRECISION

constants as from Liquidity variables.sol

SECONDS_PER_YEAR ​

solidity
uint256 SECONDS_PER_YEAR

Ignoring leap years

DEFAULT_EXPONENT_SIZE ​

solidity
uint256 DEFAULT_EXPONENT_SIZE

DEFAULT_EXPONENT_MASK ​

solidity
uint256 DEFAULT_EXPONENT_MASK

FOUR_DECIMALS ​

solidity
uint256 FOUR_DECIMALS

TWELVE_DECIMALS ​

solidity
uint256 TWELVE_DECIMALS

X14 ​

solidity
uint256 X14

X15 ​

solidity
uint256 X15

X16 ​

solidity
uint256 X16

X18 ​

solidity
uint256 X18

X24 ​

solidity
uint256 X24

X33 ​

solidity
uint256 X33

X64 ​

solidity
uint256 X64

calcExchangePrices ​

solidity
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 ​

solidity
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 ​

solidity
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 ​

solidity
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
[0]uint256withdrawalLimit_ 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 ​

solidity
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 ​

solidity
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 ​

solidity
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 ​

solidity
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 ​

solidity
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 ​

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

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

getTotalBorrow ​

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

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