Your task is to create a program, written in Haskell, that will parse and print quote messages from a market data feed. When invoked with an -r flag, the program should re-order the messages according to the ‘quote accept time’ at the exchange.
Parsing the Market Data Feed
The relevant parts of the market data feed are sent via UDP broadcast to ports 15515/15516. For the purposes of this exercise, a standard pcap file is supplied which you will use to parse the UDP packets. Quote packets (specified below) begin with the ASCII bytes "B6034", and contain the five current best bids and offers (or ‘asks’) on the market. Anything else should be ignored.
Your program should print the packet and quote accept times, the issue code, followed by the bids from 5th to 1st, then the asks from 1st to 5th; e.g.:
$ ./parse-quote mdf-kospi200.20110216-0.pcap <pkt-time> <accept-time> <issue-code> <bqty5>@<bprice5> ... <bqty1>@<bprice1> <aqty1>@<aprice1> ... <aqty5>@<aprice5> ...
Reordering on Quote Accept Time
The delay between the exchange accepting the quote and us receiving the packet fluctuates for a variety of reasons; we may even receive the packets out of order. Given an optional flag -r, your program should output the messages ordered by the quote accept time.
You should assume that the difference between the quote accept time and the pcap packet time is never more than 3 seconds.
A small sample file with a capture of the Kospi 200 market data feed from the first 30s of trading on 2011-02-16 can be downloaded here.
It is particularly important that your program runs just as efficiently on a small file as it does on a large file (8GB+), in terms of throughput and memory usage.
Quote Packet Specification
ITEM NAME len Remark --------------------------------------+---+--------------- Data Type 2 B6 Information Type 2 03 Market Type 1 4 Issue code 12 ISIN code Issue seq.-no. 3 Market Status Type 2 Total bid quote volume 7 Best bid price(1st) 5 Decimals Best bid quantity(1st) 7 Decimals Best bid price(2nd) 5 Best bid quantity(2nd) 7 Best bid price(3rd) 5 Best bid quantity(3rd) 7 Best bid price(4th) 5 Best bid quantity(4th) 7 Best bid price(5th) 5 Best bid quantity(5th) 7 Total ask quote volume 7 Best ask price(1st) 5 Best ask quantity(1st) 7 Best ask price(2nd) 5 Best ask quantity(2nd) 7 Best ask price(3rd) 5 Best ask quantity(3rd) 7 Best ask price(4th) 5 Best ask quantity(4th) 7 Best ask price(5th) 5 Best ask quantity(5th) 7 No. of best bid valid quote(total) 5 No. of best bid quote(1st) 4 No. of best bid quote(2nd) 4 No. of best bid quote(3rd) 4 No. of best bid quote(4th) 4 No. of best bid quote(5th) 4 No. of best ask valid quote(total) 5 No. of best ask quote(1st) 4 No. of best ask quote(2nd) 4 No. of best ask quote(3rd) 4 No. of best ask quote(4th) 4 No. of best ask quote(5th) 4 *Quote accept time* 8 HHMMSSuu End of Message 1 0xff