📈 Trading
Funding Rates

Funding Rates

Perpetuals futures have no expiry date, final settlement, or delivery. As such, funding rate payments are used as the incentive mechanism to bring the perpetual futures' mark price in line with the oracle price.

(For instance, a user with a long position in a market whose mark price is, on average, below the oracle price will receive a payoff proportional to their position size).

FieldDescription
Funding Rate % Calc1/24 * (market_twap - oracle_twap)/oracle_twap
TWAP ParametersEMA with span = 1 hour
Mark TWAP Calc(bid TWAP + ask TWAP) / 2
FrequencyEnd of Hour* (9:00 AM, 10:00 AM, ...)

Note: Funding rate hourly magnitudes are clamped according to the market's Contract Tier (B or greater: 0.125%, C: 0.208%, lower than C: 0.4167%) and can be delayed at large divergences (see Oracles). Individual Market TWAP updates utilize the side of the book for trade executions, Bid and Ask TWAPs in the market are calculated and/or estimated on every trade.

Unrealised -> Realised Funding

Funding rates are updated lazily every hour*.

Any time a user opens or closes a position, the exchange tries to update the funding rate.

The funding rate will still be updated if enough time has passed and no position has been opened or closed.

The update will reflect the premium or discount between the AMM’s mark price and the oracle’s price TWAP over the previous hour.

The cumulative funding rate is checked against user positions in case the off-chain funding rate bot does not trigger on the hour. This will show up as "Unrealised P&L" until your next user action within the market (such as a trade, deposit, withdraw etc.), see also P&L.

* if no market trades and/or funding update calls occur within the first ~20 minutes of the hour, the next funding update will be delayed an additional hour.

Funding payments may not pay out for markets that trade infrequently.

Capped Symmetric Funding

Drift Protocol aims to provide a symmetric funding rate to both sides of the market. When there is a long-short imbalance within the AMM, the protocol's market-specific Rebate Pool can be used to pay (or receive) the cost delta between the longs and the shorts.

If the pool is empty or does not have enough to provide for funding (2/3 of the Rebate Pool balance available at each funding interval), then the receipts for funding will be capped to the available amount.

See Rebates for funding pool sizes where the funding paid from the Rebate Pool will be capped. This ensures that the risk is spread in the system and the Insurance Fund isn't drained by funding rates.

Over the hour, the amount available in the Rebate Pool will increase from fees as trades occur, so any existing predicted capped rate should move closer to being balanced.

⬇️

Example:

For BTC-PERP you can check the recent history to get a better idea of what shorts will receive.

Example funding calculation:

1/24 * (174.643 - 174.450)/(174.450) = 0.00460% (40.27% APR)

example data

Oracle Resilience

Drift's on-chain calculation of a market's oracle TWAP is updated only on trades which incorporates the oracle's confidence interval and a few interpolations to provide the most accurate and resilient value.

Read more about protective checks in Oracles.

APR calculation

Funding rates can be showcased in annual terms for easier comparison.

APR (annual percentage rate) is calculated rate x 24 x 365.25

APY would be: (1 + rate) ^ (24 x 365.25) - 1

💡

One can approximately track APY by allocating funding receipts back into the position (excluding fees/rebates).