Skip to content
Danial Dervovic edited this page Mar 30, 2020 · 8 revisions

Tutorial: an execution experiment

This wiki page walks through the design and usage of our new RMSC03 (Reference Market Simulation Configuration). This configuration constitutes a fairly realistic model of a trading day for a highly liquid US equity.

You can follow along by executing the shell commands, or running the script ${SCRIPT}. Be warned that it can quite a long time to run.

The configuration

We describe the composition of the config below:

  • 1 Exchange Agent. This agent maintains the order book and enacts the continuous double auction mechanism for trading, acting as the message broker for all the other agents. For this type of simulation the Exchange Agent is essential as without it there can't be any trading!
  • 100 Value Agents. The Value agents have access to a shared extrinsic fundamental time series for what they believe to be the value of the stock at a given time (indeed the sparse discrete mean-reverting fundamental as seen in this wiki page). Crucially, they make noisy observations of this fundamental and then update their belief of the value of this stock in a Bayesian manner. An individual agent trades when they believe the mid price in the order book is mis-priced, that is, they buy when the stock in underpriced and sell when it's overpriced.
  • 25 Momentum Agents. The momentum agents follow a simple momentum strategy, in that they wake up at a fixed rate, observing the mid-price each time. After 50 observations the agent compares the 50-step average price p_50 with the 20-step average price p_20. If p_20 > p_50 the price is seen to be rising so the agent buys, otherwise the agent believes the price is falling so sells.
  • 5000 Noise Agents. Noise agents don't do anything particularly clever. An agent wakes up once and places a trade random direction of fixed size. The timing is such that more agents arrive right after open and just before close, mirroring observed behaviour in real markets.
  • 1 POV Market Maker Agent. This a market maker designed to provide liquidity to the synthetic market. The basic principle is to fix a window size around the mid price where the market maker places no orders. Outside this window, the market maker places an order at every price level, meaning (up to a limit imposed for computational reasons) there is always a price at which to buy or sell. POV stands for percentage of volume, in this context this means the size of the orders the market maker places is a percentage of the observed transacted volume in the previous lookback window (in RMSC03 this is set at 10 seconds).
  • 1 (Optional) POV Execution agent. The execution agent is optionally included via a command-line switch. This agent is included in the config to show the kind of experiments ABIDES allow us to do, namely counterfactual experiments. We can replay history with a new agent in the mix to see how they affect a day's trading. The POV Execution agent here is attempting to buy shares, starting at 5 minutes after opening, until 5 minutes before closing, waking up at a fixed frequency (here once every second). The quantity the agent purchases (at best ask) is set at a fraction execution-pov of observed transacted volume in the previous second. We can use this agent to investigate market impact at different percentages of volume.

TODO: Spread-based Market makers?

Experiments

Run for one seed value

Now we'll run the configuration for a short period of trading.

We'll refer to the symbol "ABM" (short for Agent-based modelling!) TODO: change to a non-existent symbol!

Plot using liquidity telemetry and explain what the plot does

Let's talk through what the above plot shows us.

The top subplot shows the mid-price for the symbol ABM, namely, the half way point between the best bid (offer to buy) and best ask (offer to sell). Also displayed is the value for the fundamental, as seen by the value agents. We see that the mid-price closely tracks the fundamental price. Indeed this is induced by the pressure from the Value Agents. If they see the symbol is mispriced, they will trade in such a way as to take advantage of this, which acts to close the gap between mid-price and fundamental.

The second subplot shows the spread over time for the symbol, defined as the difference between the best bid and best ask. Typically, large tick stocks are those that have a spread of approximately one tick [1], with small tick stocks having a larger spread. For us a large tick stock would mean a spread of one cent. Here ABM has a slightly larger spread; we can think of ABM as being "medium tick".

The third subplot shows participation of volume. This is defined as the number of shares offered at the best ask divided by the sum of shares offered at best bid and best ask. Roughly speaking, a participation of volume close to one means there is more supply for the stock and participation of volume close to zero means there is a lot more demand. Here we see that this quantity is very rapidly oscillating between zero and one as there is a lot of trading happening in the market.

The fourth subplot is empty, and it should be empty! This subplot is there to check that there is sufficient liquidity in the synthetic market, with a vertical line appearing whenever any "liquidity dropout events" occur. These are when one side of the order book is empty, that is, there is no offer at any price to buy (resp. sell) the security.

The bottom subplot shows how much volume is transacted over the day, as in, how many shares are being traded over a unit of time. As ABM is a highly liquid stock we see a large a volume of transactions.

Experimental Agent Config

Now we're placed to run an experimental agent within this config. You'll notice that the configuration has an --execution-agents command-line switch. If activated, this indicates that there will be an additional agent present: an execution agent. One of the benefits of the randomness model in ABIDES is that we can run counterfactual experiments, that is, we can add or remove agents from a simulation run and observe the difference in the synthetic market's behaviour.

The goal of the execution agent is to carry out a large order, known as a metaorder. A metaorder is realised by a collection of smaller orders, known as child orders. An example would be a metaorder to buy 10000 shares in ABM, split into 100 child orders, each order comprising a buy order for 100 shares.

The execution order used in the RMSC03 configuration is called a POV execution agent, standing for "percentage of volume". There are other types of execution agent provided in ABIDES, in the agents/execution directory. The POV execution agent is given a target quantity and percentage of volume (POV). At each wakeup, the agent queries the exchange for the total transacted volume since the last wakeup, then places an order with size pov * transacted_volume. The agent stops when the metaorder is fulfilled, although the implementation in ABIDES allows the agent to stop at a specified time also for experimental purposes. Naturally, a larger POV will result in a faster metaorder execution and a smaller POV will be slower. However, a larger POV will have a larger impact on the mid-price as the agent's transactions take up a larger proportion of traded volume.

Single day comparison plot at multiple POV

Using the RMSC03 config we can run a counterfactual experiment: what impact does a POV execution agent have on the synthetic market defined by the RMSC03 config? How does this increase as the POV level increases?

We'll consider the POV agent particiapting at a number of POV levels: 0.01, 0.05, 0.1 and 0.5. The agent will be executing a buy metaorder over the time period 09.35 -- 10.45.

Single day plot

The top subplot shows the mid-price with no execution agent (baseline) along with the price series for each participation level. The time period during which the execution is active is shown my the greyed panel. Notice that before the agent is active, the price series at all POV participation levels levels is the same as the baseline, showing us that the changes in mid-price can be attributed to the action of the execution agent.

The bottom subplot shows the same data, but scaled to the baseline mid-price (horizontal line at y = 0). TODO check. We can see that for the seed chosen, the mid-price impact roughly increases with the POV level.

Aggregated execution experiment

The plot in the previous section corresponds to a single simulation run. In a similar way to real markets, our synthetic market shows a lot of variation over different time periods. As such, to draw strong conclusions about market properties, results from multiple simulations must be aggregated. For our execution experiment, we'll do the same below.

Multiday subplot

These plots are much like the bottom subplot of the previous subsection -- with the main differences being the POV levels being on separate plots for visibility and uncertainty being quantified by quantile bands around the difference from baseline mid-price. We see that increasing POV increases the average change in mid-price, as one might expect.

Conclusion

In this tutorial we have seen how to run a small counterfactual experiment using the latest reference market simulation configuration (RMSC03) and some of the plotting utilities that allow us to inspect ABIDES simulation results. The best way to learn how to use ABIDES is to take the provided configs and play around with the default parameters. The wiki pages contain lots of further useful information as well.

Thanks for following along and happy simulating!

====

[Bouchaud_Kockelkoren] The price impact of order book events: market orders, limit orders and cancellations. Zoltan Eisler, Jean-Philippe Bouchaud, Julien Kockelkoren. Quant. Finance, 2012, 12, 1395–1419 arXiv:0904.0900 [q-fin.TR]

Clone this wiki locally