Bin Math

Introduction

As you dive into the contracts, you will find a lot of bin math that can be terribly confusing. This section aims to resolve any confusion.

Bin Pricing

Even though price of any given asset can range from 0 to infinity, we are constrained to 256 bits and the largest number a uint256uint256 can hold is 225612^256 − 1. However, we also need to account for very small fractions, so we use 128.128 binary fixed-point numbers instead. These numbers use the left 128 bits for all numbers to the left of the decimal (i.e. the integers) and the right 128 bits for all numbers to the right of the decimal (i.e. the fractions). Thus the price range of every asset is now constrained to [2128,2128)[2^{−128},2^{128})instead; the maximum of which is already very, very large and the minimum of which is already very, very small. Not quite 0 and infinity, but pretty much close to it.

Bin Limits

Now that we have the lower and upper bounds of price and we discretized the entire price curve into bins, how many bins could we possibly have?

Remember how the price of each bin was basically a geometric sequence (1+s)i.(1+s)^i . We now need to find the maximum integer for ii such that the entire value is less than the upper limit of price, 2128.2^{128}.

In the whitepaper this is expressed as argmaxi((1+s)i<2128)argmax_i​ ((1+s)^i<2^{128}).

Taking the smallest possible value of ss which is 1 basis point, we can solve this as follows:

(1+0.0001)i<2128(1+0.0001)^i<2^{128}
log2(1.0001)i<log2(2128)\log\nolimits_2​(1.0001)^i<\log\nolimits_2​(2^{128})
i.log2(1.0001)<128i.log2​(1.0001)<128
i<128log2(1.0001)887,273i<\dfrac{128}{\log\nolimits_2​(1.0001)}≈887,273
i=887,272i=887,272

The above equation shows how many bins are needed to cover the entire range when ii is a positive integer, so we account for when it is negative by doubling it which equals to 2887,272=1,774,5442∗887,272 = 1,774,544 bins.

However, remember that ii can also be negative, so the smallest signed integer that can fit this many bins is an int24. A quick sanity check shows that the largest integer for an int24 is 2231=8,388,6072^{23}−1=8,388,607 which is still plenty large enough to hold the largest ii, which is 887,273887,273.

So even though we previously said the upper and lower limits of price was [2128,2128)[2^{−128},2^{128}), we can also define the limits using how many bins there could possibly be, which comes to [(1+s)223,(1+s)223[(1+s)^{2^{-23}},(1+s)^{2^{23}} . However, if we are to be extremely technical, the actual limits will be the minimum of the two.

Last updated