Skip to main content
In Bend, the interest rate you pay as a borrower is set by an Interest Rate Model (IRM) chosen when the market is created. The only IRM used for Bend markets is the AdaptiveCurveIRM. It differs from typical pool IRMs in two ways:
  1. Immutable: The model cannot be changed or upgraded. It must respond automatically to market conditions, including rates on other platforms.
  2. Higher target utilization: Supplied assets in Bend are not used as collateral, so markets don’t need to hold large buffers for liquidations. The protocol can target higher utilization and use gentler illiquidity penalties.
The AdaptiveCurveIRM keeps utilization near 90%. In the short term it avoids utilization drifting too low or too high; over time the rate adapts to market conditions. Two mechanisms work together:

The Curve Mechanism

This mechanism resembles the interest rate curves commonly found in traditional lending protocols. The curve is defined by the following features:
NameDescription
Target Rater90%r_{90\%} (corresponding to a target utilization of 0.9)
Fixed Steepness Parametersc = 4
Morpho - Curve Mechanism
Image provided by Morpho Docs
Each time you (or any user) interact with the market—e.g. borrow or repay—utilization changes and the rate updates along the curve. For instance, the following are sample utilization-to-rate relationships:
UtilizationRate
90%r90%r_{90\%}
100%4×r90%4 \times r_{90\%}
The Curve Mechanism is designed to respond to short-term fluctuations in utilization, helping maintain healthy market liquidity during periods of sudden borrowing or repayment.

The Adaptive Mechanism

This mechanism continuously shifts the curve to adjust to market conditions over time. The curve shifts over time so the rate adapts to market conditions even when no one is borrowing or repaying.
Morpho - Adaptive Mechanism
Image provided by Morpho Docs
The adaptive mechanism dynamically shifts the rate curve in response to changing market conditions, even during periods without user interaction. The key value that moves the curve is r90%r_{90\%}—the rate at the target utilization. This value gradually changes over time:
  • If utilization rises above the target (90%), r90%r_{90\%} will steadily increase.
  • If utilization falls below the target, r90%r_{90\%} will steadily decrease.
The pace at which r90%r_{90\%} moves is recalculated whenever the market is updated (such as through borrowing or repaying). The greater the gap between current and target utilization, the faster r90%r_{90\%} (and thus the whole curve) moves in the appropriate direction. Example: if utilization stays at 100% for five days, r90%r_{90\%} can roughly double in that period (at maximum speed).
The values of some constants are hardcoded into the code deployed on Berachain, such as TARGET_UTILIZATION, INITIAL_RATE_AT_TARGET, etc.

Formula breakdown

NameDescription
uuutilization - total assets borrowed divided by total assets supplied
tttime - the specific moment at which utilization and other parameters are evaluated
u(t)u(t)Ratio of total borrow over total supply at time
utarget=0.9u_{\text{target}} = 0.9Constant target value for utilization (set to 0.9) that the model aims to maintain.
t\forall tFor all time
eeerror - Difference between the current utilization and the target utilization, divided by a normalization factor
kdk_{\text{d}}Constant that controls how sharply the interest rate increases when utilization exceeds the target
HHThe time step (in seconds) between two interest rate updates
lastlastMost recent interaction time before or at a specific time
speed(t)speed(t)Factor controlling how quickly the interest rate evolves based on utilization changes over time
rrBorrow rate
rTr_{\text{T}}Rate at target - Interest rate corresponding to the target utilization, updated over time using the speed factors

Utilization

Utilization (u(t)u(t)) is the ratio of total borrowed assets to total supplied assets at time (tt), with a constant utilization target (utarget=0.9u_{\text{target}} = 0.9).

Error

Error (e(u)e(u)) is the normalized difference between the current utilization (u(t)u(t)) and the target utilization (utargetu_{\text{target}}), scaled so that the distance between utargetu_{\text{target}} and u=1u = 1 equals the distance between utargetu_{\text{target}} and u=0u = 0. t,e(u)={u(t)utarget1utarget,if u(t)>utargetu(t)utargetutarget,if u(t)utarget\forall t, \quad e(u) = \begin{cases} \dfrac{u(t) - u_{\text{target}}}{1 - u_{\text{target}}}, & \text{if } u(t) > u_{\text{target}} \\ \dfrac{u(t) - u_{\text{target}}}{u_{\text{target}}}, & \text{if } u(t) \le u_{\text{target}} \end{cases}
Morpho - Formula Error
Image provided by Morpho Docs

Curve

Curve (curve(u)curve(u)) determines the shape and sensitivity of the interest rate response to changes in utilization around the target, with different slopes below and above utargetu_{\text{target}} controlled by the constant kdk_{\text{d}}. curve(u)={(11kd)e(u)+1,if uutarget(kd1)e(u)+1,if u>utarget\text{curve}(u) = \begin{cases} \left(1 - \dfrac{1}{k_d}\right) \cdot e(u) + 1, & \text{if } u \le u_{\text{target}} \\ \left(k_d - 1\right) \cdot e(u) + 1, & \text{if } u > u_{\text{target}} \end{cases} with kd=4k_d = 4

History of interactions

History of interactions (HH) represents the set of all past interaction times up to time (tt), including the initial time (00). Noting that tit_{\text{i}} the time at which ithi\text{th} interaction occurred. t,H(t)={0}+{ti}ti<t\forall t, \quad H(t) = \{0\} + \{t_i\}_{t_i < t}

Last interaction

Last interaction (lastlast) represents the most recent interaction time before or at time (tt). t,last(t)=max(H(t))\forall t, \quad \text{last}(t) = \max(H(t))

Speed

Speed factor (speedspeed) determines how fast the interest rate changes over time based on the error at the last interaction, scaled by (kpk_\text{p}). t,speed(t)=exp ⁣(kpe(u(last(t)))(tlast(t))),with kp=50\forall t, \quad \text{speed}(t) = \exp\!\left(k_p \cdot e(u(\text{last}(t))) \cdot (t - \text{last}(t))\right), \quad \text{with } k_p = 50

Rate at target

Rate at target (rtargetr_{\text{target}}) represents the interest rate when utilization equals the target utilization, evolving over time based on the speed factor. t>0,rT(t)=rT(last(t))speed(t)\forall t > 0, \quad r_T(t) = r_T(\text{last}(t)) \cdot \text{speed}(t) At any time (tt), the borrow rate (rr) is given by the formula: r(t)=rT(t)curve(u(t))r(t) = r_T(t) \cdot \text{curve}(u(t))

Calculations

APY is the annualized return for suppliers and cost for borrowers, with compounding. In Bend you use it to compare returns and costs across markets.

Borrow APY

The Borrow APY is calculated using the following formula: borrowAPY=(e(borrowRate×secondsPerYear)1)\text{borrowAPY} = \left( e^{(\text{borrowRate} \times \text{secondsPerYear})} - 1 \right) Where:
  • borrowRate is the borrow rate per second, as determined by the Interest Rate Model (IRM).
  • secondsPerYear represents the total number of seconds in a year (31,536,000).

Supply APY

The Supply APY is calculated considering the utilization and the fee. The formula is: supplyAPY=borrowAPY×utilization×(1fee)\text{supplyAPY} = \text{borrowAPY} \times \text{utilization} \times (1 - \text{fee}) Where:
  • fee is the fee of the market on a per-market basis and portion of the interest paid by borrowers that is retained by the protocol. See Yield & Fees for more details.
  • utilization is calculated as:
utilization=totalBorrowAssetstotalSupplyAssets\text{utilization} = \frac{\text{totalBorrowAssets}}{\text{totalSupplyAssets}}

Constants

The values of the following constants are hardcoded into the Morpho code deployed on Berachain.
  • WAD = Wei-based Decimal (WAD = 10^18, meaning 1 WAD = 1.0)
ParameterDescriptionValue
CURVE_STEEPNESSCurve steepness (scaled by WAD)4
ADJUSTMENT_SPEEDAdjustment speed per second (scaled by WAD)50/# of seconds per year
TARGET_UTILIZATIONTarget utilization (scaled by WAD)90%
INITIAL_RATE_AT_TARGETInitial rate at target per second (scaled by WAD)4%/# of seconds per year
MIN_RATE_AT_TARGETMinimum rate at target per second (scaled by WAD)0.1%/# of seconds per year
MAX_RATE_AT_TARGETMaximum rate at target per second (scaled by WAD)200%/# of seconds per year