Skip to content

Cover Pools

Cover Pools allow you to create positions to increase exposure to a specific token conditional on it increasing in price on a given pair.

  • If the ETH price increases, the pool sells DAI and increases the amount of ETH exposure
  • If the ETH price decreases, the pool sells ETH and increases the amount of DAI exposure

If a position is or has been in range on a bidirectional automated market maker it increases the exposure to the token dropping in price or has all exposure in the token dropping in price.

  • If the market wants ETH, the pool takes DAI and increases the ETH to DAI price
  • If the market wants DAI, the pool takes ETH and decreases the ETH to DAI price.

    Range Order 1

    This allows them to function as a hedging tool if the user wants to enter or exit an ERC-20 token over some range.

If this was attempted using a position with a fixed price such as a limit order (as done when providing liquidity) the position will either underprice the assets or it won't be filled.

Cover pools allow you to create a position to provide liquidity at a set price and when the TWAP price nears the liquidity becomes available to trade. The liquidity is then a part of a dutch auction.

Cover Pools operate with a Gradual Dutch Auction (GDA) meaning that you can start at the price indicated by the current price tick of your position and begin to offer a more discounted price until it is accepted by the market.

As a Range Order, Cover Positions will unlock periodically unlock liquidity across a price range as the Time-Weighted Average Price (TWAP) increases or decreases (indicated by the user).

This is because we don't want the pool to unlock liquidity due to high frequency market volatility which will be closed out on an extremely short time period due to arbitrage.

Applications (non-exhaustive)

Covering Potential Impermanent Loss

If you are seeking to cover impermanent loss dynamically as the price moves, it is ideal for your lower and upper bound to match your current position on either Uniswap v3 or Poolshark. It is okay to put the same upper and lower bound as on your original Range Position NFT. The PoolsharkCoverPair contract will automatically calculate how much input token you should transfer into the pool based on the currently valid price range.

If the user wants to increase capital efficiency, they can either increase the lower bound or decrease the upper bound so that less upfront capital is required.

Rather, Cover positions are meant to decrease exposure of one asset and increase exposure to another as the price of the initial asset becomes worse. This is a way for LPs to hedge a portion of their portfolio in the case the market price moves against a given asset.




Range Order 1

Assuming the user wants to cover any potential impermanent loss, this range should match their original LP position and the value of the position should also be equal to more accurately cover impermanent loss.

Trading Conditional on Price Changes

For users seeking to trade into an asset starting at some price (example in the image below), they can set the lower bound as the point where they want to start transitioning from the input token to the output token.

The Cover Pool will unlock liquidity at each price point based on the total amount of liquidity available in the pool for a given pair direction.

Capital efficiency can be improved by selecting a smaller range over which to trade to the desired output token.

Cover LP Positions can also be used to deleverage long or short positions prior to getting liquidated.

How Auctions Work

In order to be competitive with the current market rate, the pool must have a dynamic pricing mechanism so the position is filled as soon as possible while keeping any discount at a minimum. For this, Cover Pools use Gradual Dutch Auctions to raise or lower the pool price (depending on buying or selling a token) to satisfy market demand for an asset within a trading pair at that point in time.

From Paradigm's Gradual Dutch Auction article:

Here, the price for every auction decays exponentially according to some `decay constant`.
The starting price of each auction increases by some fixed `scale factor`.
And the starting price of the first auction is given by some `initial price`.

Combining these values gives us a exponentially changing market price for each tick of liquidity we auction off. The price will never deviate by more than one price tick (e.g. 0.1% for the ETH-USDC 0.05% tier).

How Volatility Tiers work

Volatility tiers set a few different parameters when a pool is created being the auction length, syncing fee, minimum position size, minimum position width.

Auction length is the amount of blocks until the next auction can be triggered by a price change.

A syncing fee is for when an auction goes unfilled and it needs to be moved to the next price tick in which liquidity is added to the auction at the new price tick.

Minimum position size is the minimum amount of liquidity required at a price tick to commence an auction.

Minimum position width is the minimuim amount of price ticks a position can span.