We introduce a new invariant function associated with generalised mean that underpins the ALEX AMM. ALEX builds DeFi primitives targeting developers looking to build ecosystem on Bitcoin, enabled by Stacks. With a suitable parameterisation, the invariant function supports both risky pairs (i.e. xy=L), stable pairs (i.e. x+y=L) and any linear combination in-between (i.e. Curve). We also show that our invariant function maps L to the liquidity distribution of Uniswap V3.
Introduction
At ALEX, we build DeFi primitives targeting developers looking to build ecosystem on Bitcoin, enabled by Stacks. As such, we focus on trading, lending and borrowing of crypto assets with Bitcoin as the settlement layer and Stacks as the smart contract layer. At the core of this focus is the automated market making ("AMM") protocol, which allows users to exchange one crypto asset with another trustlessly. This paper focuses on technical aspects of AMM.
AMM and Invariant Function
ALEX AMM is built on three beliefs: (i) it is mathematically neat and reflect economic demand and supply and (ii) it is a type of mean, like other AMMs.
We will firstly review some desirable features of AMM that ALEX hopes to exhibit.
Properties of AMM
AMM protocol, which provides liquidity algorithmically, is the core engine of DeFi. In the liquidity pool, two or more assets are deposited and subsequently swapped resulting in both reserve and price movement. The protocol follows an invariant function f(X)=L, where X=(x1ā,x2ā,ā¦,xdā) is d dimension representing d assets and L is constant. When d=2, which is the common practise by a range of protocols, AMM f(x1ā,x2ā)=L can be expressed as x2ā=g(x1ā). Although it is not always true, g tends to be twice differentiable and satisfies the following
monotonically decreasing, i.e. dx1ādg(x1ā)ā<0. This is because price is often defined as ādx1ādg(x1ā)ā. A decreasing function ensures price to be positive.
convex, i.e. dx12ād2g(x1ā)āā„0. This is equivalent to say that ādx1ādg(x1ā)ā is a non-increasing function of x1ā. It is within the expectation of economic theory of demand and supply, as more reserve of x1ā means declining price.
Meanwhile, f can usually be interpreted as a form of mean, for example, mStable relates to arithmetic mean, where x1ā+x2ā=L (constant sum formula); one of the most popular platforms Uniswap relates to geometric mean, where x1āx2ā=L (constant product formula); Balancer, which our collateral rebalancing pool employs, applies weighted geometric mean. Its AMM is x1w1āāx2w2āā=L where w1ā and w2ā are fixed weights. ALEX AMM extends these to create a generalised mean.
ALEX AMM
After extensive research, we consider it possible for ALEX AMM to be connected to generalised mean defined as
(d1āi=1ādāxipā)p1ā
where 0ā¤pā¤1. The expression might remind readers of p-norm when xiāā„0. It is however not true when p<1 as triangle inequality doesn't hold.
When d=2 and p=1āt(0ā¤t<1) is fixed, the core component of generalised mean is assumed constant as below.
This equation is regarded reasonable as AMM, because (i) function g where x2ā=g(x1ā) is monotonically decreasing and convex; and (ii) The boundary value of t=0 and t=1 corresponds to constant sum and constant product formula respectively. When t decreases from 1 to 0, price āx1ādg(x1ā)ā gradually converges to 1, i.e. the curve converges from constant product to constant sum (see Appendix 1 for the relevant proofs).
Though purely theoretical at this stage, Appendix 2 maps L to the liquidity distribution of Uniswap V3. This is motivated by an independent research from Paradigm.
Trading Formulae
Market transaction, which involves exchange of one crypto asset and another, satisfies the invariant function. Please note the formulae do not account for the fee re-investment, which results in a slight increase of L after each transaction, like Uniswap V2.
Out-Given-In
In order to purchase Īy amount of token Y from the pool, the buyer needs to deposit Īx amount of token X. Īx and Īy satisfy the following
(x+Īx)1āt+(yāĪy)1āt=x1āt+y1āt
After each transaction, balance is updated as below: xāx+Īx and yāyāĪy. Rearranging the formula results in
Īy=yā[x1āt+y1ātā(x+Īx)1āt]1āt1ā
When transaction cost exists, the actual deposit to the pool is less than Īx. Assuming Ī»Īx is the actual amount and (1āĪ»)Īx is the fee, above can now be expressed as
Sometimes, trader would like to adjust the price, perhaps due to deviation of AMM price to the market value. Define pā² the AMM price after rebalancing the token X and token Y in the pool
pā²=(x+Ī»ĪxyāĪyā)t
Then, the added amount of Īx can be calculated from the formula below
ALEX's invariant function is f(x1ā,x2ā;p)=x1āp+x2pā=L. It can be rearranged as x2=g(x1ā)=(Lāx1pā)p1ā. x1ā and x2ā should both be positive meaning the liquidity pool contains both tokens.
Theorem
When 0<p<1, g(x1ā) is monotonically decreasing and convex.
Proof
This is equivalent to prove dx1ādg(x1ā)ā<0 and dx12ād2g(x1ā)āā„0.
The last inequality holds because each component is positive.
When p= 1, it is straightforward to see that the invariant function is constant sum. To show that the invariant function converges to constant product when p= 0, we will show and prove an established result in a generalised d dimensional setting.
(d1āāi=1dxipā)p1ā=exp[plog(d1āāi=1dxipā)ā]. Applying L'Hospital rule to the exponent, which is 0 in both denominator and nominator when pā0, we have
Proof of the corollary is trivial, as it is a direct application of the theorem. It shows that generalised mean AMM implies constant product AMM when pā0.
Appendix 2: Liquidity Mapping to Uniswap v3
As Uniswap v3 is able to simulate liquidity curve of any AMM, we are interested in exploring the connection between ALEX's AMM and that of Uniswap's. Interesting questions include: what is the shape of the liquidity distribution? Which point(s) has the highest liquidity? We acknowledge that the section is more of a theoretical study for now.
Uniswap V3 AMM can be expressed as a function of invariant constant L with respect to price p, LUniswapā=dpādyā. For us, the difference in the invariant function means we can write price as p=ert (or, equivalently, r=t1ālnp ) and we have
LUniswapā=dpādyā=t2āeā21ārtdrdyā
Based on the previous sections, we can then express y as
Figure 1 plots LUniswapā against r (which is proportional to p) regarding various levels of t. When 0<t<1, LUniswapā is symmetric around 0% at which the maximum reaches . This is because
cosh[(2r(1āt)ā)] is symmetric around r= 0% with minimum at 0% and the minimum value 1;
xz is a decreasing function of x when x is positive and power z is negative. In our case, we have z=1ātā2+tā<ā1. Therefore, it is the maximum rather than minimum that LUniswapā achieves at 0.
Furthermore, the higher the t, the flatter the liquidity distribution is. When t approaches 1, i.e. AMM converges to the constant product formula, the liquidity distribution is close to a flat line. When t approaches 0, the distribution concentrates around 0%.