This is a very fast implementation of the ITCH order book, clocking in at around 61ns / tick (or 16 million messages / second), offering fast updates and O(1) access to any price level (to get the price is a single dereference, the aggregate quantity is another dereference). It only calculates the aggregate quantities at each price and does not track the queue depth for each order.
Among other things, there is no hashtable or trees used, only <vector>
s and C arrays, and no allocation beyond what <vector>
does. For description and implementation see order_book.h.
Protocol specification: http://www.nasdaqtrader.com/content/technicalsupport/specifications/dataproducts/NQTVITCHSpecification.pdf.
In order to run it, ./build.sh && ./a.out < [file]
. Note that the implementation is fast enough that you will likely to be I/O bound - in order to find out how fast it really is you should 'warm-up' by loading the file into the buffer cache using cat [file] > /dev/null
.