ryuzaki Profile picture
Dec 5, 2021 36 tweets 6 min read Read on X
My last thread on market making concluded that managing inventory risk is key to staying in the MM business

This one’s dives into exactly what that means, and I’ll walk through a cheeky math model for how to do it as a full automated / algorithmic trader
A few preliminaries

you should know market structure & terminology basics if you don’t already (e.g. order types, LOBs, spreads), this is a good intro, machow.ski/posts/2021-07-…

you should read the original thread first, this one is more advanced,
The model here is from the paper “HFT in a limit order book” by Avellaneda & Stoikov. The derivation is non-trivial so I’ll focus on the motivation and results here
math.nyu.edu/~avellane/High…
Every MM and their mother knows this paper so there’s no unique alpha here, *but* it is the foundation of many models and you should know it too

And ofc none of this financial advice, just theoretical quanty shit
Let's start with some motivation

Consider a pawn shop

When a customer arrives wanting to sell, you do a few things:
(1) Value their stuff best you can
(2) Offer to buy it below your valuation
(3) If they accept, store it until you can flip it for more than you paid for it
That’s roughly the MM business

Your store is your portfolio and the inventory you keep in it is financial assets, I like this comparison because it makes the term inventory risk clearer

If you’re running a business like this what are your major risks?
Principally, the risks are:
(1) bad valuations make you trade at bad prices
(2) you buy something but can't find anyone to sell it to
(3) price moves adversely b/w the time you buy and sell
(4) you bought too much and run out of cash until you sell some
A good market making model should manage for all of these

Let’s think about the flip side of what a profitable MM operation should look like again
Let’s say XYZ/USDT trades on exchanges A and B and you wanna make a market in it on A

You go long $100k XYZ on A and short $100k XZY on B at the start of the trading day, now you have a delta-neutral position on A to use for use for providing liquidity
Sanity check - why do we do this? Because trading happens both ways, and to sell something you must own it. Hedging like this lets you own it without assuming market risk

Now you only care about diff b/w the position on A and B (delta), which varies as your orders fill on A
If your buys/sells are filled evenly, your delta stays close to zero, but if flow is very one-sided, you could get into trouble if you don’t adapt

How do you adapt to one-sided flow?
A few ways:
(1) Resize your hedge with a market order on B
(2) Widen your quotes to adjust for uncertainty
(3) Skew your quotes based on your delta
(4) Skew your quotes based on alpha signals
Adjusting your hedge is the easiest way, but it’s relatively expensive

You gotta pay taker fees and cross the spread on B, hedging can eat into margins p badly

We should focus more on techniques 2-4 instead to make more money
For (2)

Suppose XYZ has a mid-price of $100, what’s the difference between quoting $99 @ $101 vs. $95 @ $105?

Namely the tradeoff is high volume + low margins vs. low volume + high margins

The latter also gives you more room for uncertainty in the future value of the asset
How do you quantify uncertainty in the future value of the asset?

You should’ve said volatility (i.e. variance of returns over a lagging period)

The takeaway is that to implement (2), our MM model should widen its pricing when volatility is high
Again, for XYZ, what’s the difference between quoting $95 @ $105 and $99 @ $105?

In the latter, you’re more likely to buy than sell because the bid is way closer to market value than the ask
This is attractive if your delta is too negative - the asymmetry adjusts the probability of getting fills in the direction you want

Important to emphasize this skew isn't based on future predictions, it’s only adjusting pricing based on the current state of *your* portfolio
It’s purely reactive, not predictive

If you have alpha signals, you could incorporate those into the MM model as well to position yourself more favorably for the future state of the market, but this is obvious

This can greatly help to reduce adverse selection but is hard
OOK if you’re still here and reading it is time to talk maths

I’m going to refer to this model as A&S going forward (after the authors initials)
A&S provides a 2-step procedure for optimally providing liquidity

(1) Compute an “indifference” price
(2) Compute the optimal spreads based on (1)
what the fuck is an indifference price

I’m glad you asked

it’s the price at which you’d be indifferent to buying/selling one more unit of the asset you’re trading

in simplest terms, it answers “how cheap would I need to this thing to be to reasonably buy more of it?”
the idea is that if you’ve bought a lot, you won’t want to buy more unless it’s a price far below market value

and conversely, you wouldn’t mind selling to others close to market value since you’ve got so much at the moment
A&S defines the indifference price as

r(s,q,t) = s – q * gamma * sigma^2 * (T – t)

where:
s = mid-price
q = inventory
gamma = risk-aversion param
sigma = volatility
T = end time
t = current time
If q > 0, r < s indicating a desire to sell, and vice-versa with q < 0 indicating a desire to buy

If sigma >> 1, volatility is high and your pricing is further from mid-price

That captures the basics of what we want already
How do we derive the optimal spreads around this price?

What even makes a spread optimal?
A&S specifically defines the value function

u(s,x,q,t) = max E [ -exp(-gamma (X_t + q_T S_T)) ]

where:
max is over delta(a), delta(b)
E = expected value
X_t = cash
q_t = inventory
S_t = mid-price

(X, q, s are all stochastic)
In other words, we're maxxing the EV of our net worth given the spreads we choose

The procedure to solve that for values of delta(a), delta(b) is non-trivial but I’ll give the result
The optimal spreads are:

d(a) + d(b) = gamma * sigma^2 * (T-t)
+ (2 / gamma) ln(1 + (gamma / k))

where:
d(a), d(b) = ask spread, bid spread
k = orderbook density param
everything else the same
The value k comes from how we model the order flow we receive and there’s some nuance in it

The simple way to think about it is high liquidity, high volume = higher value for k

I’ll provide some more info but for now a quick recap
In A&S, the params you have control over are gamma (personal risk-aversion), k, and T (end-time)

With those you can compute the reservation price, the optimal spreads to quote around it, and begin market making with some inventory control
Finally let’s talk about modeling order flow

Specifically, we’d consider the frequency, size distribution, and impact of market orders on price

Let’s say frequency is constant, like total volume / avg. size of order
The distribution of size market order size is typically modeled as a power law, A&S gives it as f(x) ~ x^{-1 – alpha} where alpha is a constant around 1.3-1.5 (derived empirically)

Market impact is harder, but A&S uses dP ~ ln(Q) where dP = change in price, Q = quantity
We can put all of these together to model orderflow as a Poisson process parameterized by lambda

That parameter lambda is itself a function of the spread we choose
Based on the previous equations, A&S models lambda(delta) ~ A exp(-k delta)
where
A = frequency of MOs
k = alpha * K
K = proportionality constant

You’d typically do a regression against market data to get at a good value of K, but I’ve said enough for now
Future things to consider if you really wanna print money:
- how you define the fair value of an asset (is the mid-price really good or is it unreliable sometimes?)
- how do tick sizes and exchange rules affect your strategies?
- how do you incorporate alpha into your pricing?
Sorry this thread was a billion tweets long, I feel like a VC influencooor

Hope it was a helpful starting point and at least kinda understandable

MM is a pretty complex game and this is one of the harder parts of it

• • •

Missing some Tweet in this thread? You can try to force a refresh
 

Keep Current with ryuzaki

ryuzaki Profile picture

Stay in touch and get notified when new unrolls are available from this author!

Read all threads

This Thread may be Removed Anytime!

PDF

Twitter may remove this content at anytime! Save it as PDF for later use!

Try unrolling a thread yourself!

how to unroll video
  1. Follow @ThreadReaderApp to mention us!

  2. From a Twitter thread mention us with a keyword "unroll"
@threadreaderapp unroll

Practice here first or read more on our help page!

More from @0xRyuzaki

Apr 30, 2022
To round out the trilogy, I figured I'd write a third and final thread with some more qualitative insights and thoughts on market making and profitable liquidity provision

No math this time, but lots of important concepts to understand in practice
I'll frame things first by discussing limitations of the model from my last thread ("A&S")

There are several:
(1) "Optimal" pricing might be too wide to get fills
(2) It assumes prices are stochastic (random)
(3) Inventory control is reactive, not predictive
For (1), 'optimal' pricing is only optimal insofar as you can get filled there

If your optimal spreads are +1/-1% but 90% of taker volume occurs within 10bps, you'll never get a trade

(and you need trades to make money)
Read 22 tweets
Sep 13, 2021
gm crypto twitter

thought I'd kick things off by dropping some knowledge on electronic market making

a thread on how institutions are built by programming computers to buy low sell high
absolute basics:

market makers ("MMs") provide liquidity to a market by posting orders on the LOB

they buy slightly below the market price and sell slightly above it, i.e. if mid is $100 they post bids at $99, asks at $101, and make $2q per round trip (q = quantity traded)
I won't explain too many basics beyond that because it's been done elsewhere and I want to get into the good stuff

if terminology in the last tweet was confusing or you are a total n00b read this real quick to get up to speed
investopedia.com/terms/m/market…
Read 17 tweets

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just two indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3/month or $30/year) and get exclusive features!

Become Premium

Don't want to be a Premium member but still want to support us?

Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal

Or Donate anonymously using crypto!

Ethereum

0xfe58350B80634f60Fa6Dc149a72b4DFbc17D341E copy

Bitcoin

3ATGMxNzCUFzxpMCHL5sWSt4DVtS8UqXpi copy

Thank you for your support!

Follow Us!

:(