Optimal arbitrage on constant product liquidity pools

The crypto world brings a new set of rules that create a large and diverse set of opportunities. For example: the atomicity of transactions lets one borrow millions of dollars with no collateral through the use of flash loans. This is only possible due to the guarantee that is given to us by smart contracts on blockchains: code is law.

Perhaps one of the most exciting, and most popular, applications of smart contracts has been decentralized exchanges. These exchanges run as programs on the blockchain and allow one to trade one asset for another through the use of liquidity pools. These pools can have any two tokens α and β and use some mathematical function to price these two assets according to the amount they have of each.

Given this fact, one can imagine a pretty trivial scenario: there are 2 decentralized exchanges each of which has a pool for the same 2 assets, trading at the same rate. At some point, someone makes a trade on one of those pools and the rates become imbalanced. You can buy one of these assets at a discount on one pool and sell them for a premium on the other. Hence, you can make a profit.

But, how much do I buy and sell?

This is the best part! Recall that these assets are priced with some mathematical function such that the marginal price is increasing. In fact, the most common function is the constant product function, which simply says the following: the product of the 2 amounts of assets needs to be constant. For example lets say we have a pool that trades α and β and this pool has Rα amount of token α and Rβ amount of token β. Then the constant product says the following: RαRβ=k, thus when you trade an amount in of token β, the amount of token α that comes out will be exactly such that the new amounts still multiply to RαRβ=k=(RαΔα)(Rβ+Δβ) hence Δα=RαRαRβRβ+Δβ.

Lets go back to the scenario in which we have two pools 1 and 2, where on the first pool we can buy α at a discount. Then we want to trade β for α on pool 1 and trade that α for β on pool 2. Hence we use Δ1α=R1αR1αR1βR1β+Δ1β as an input for the second pool. Thus we have

Δ2β=R2βR2βR2αR2α+Δ2α Δ2α=Δ1α Δ2β=R2βR2βR2αR2α+R1αR1αR1βR1β+Δ1β

Where our profit is simply the difference Δ2βΔ1β, thus we want to input the amount of tokens that maximizes our profit: Δ1β=maxΔ1βΔ2βΔ1β.

Therefore our optimal amount in Δ1β is:

Δ1β(R2βR2βR2αR2α+R1αR1αR1βR1β+Δ1βΔ1β)=0 Δ1β=±R2αR2βR1αR1β+R1αR1βR2α+R1αR1β · math, crypto, arbitrage