Skip to content

Latest commit

 

History

History
109 lines (79 loc) · 5.11 KB

README.md

File metadata and controls

109 lines (79 loc) · 5.11 KB

engine-takehome-interview

Prompt

Your application is a matching engine that receives orders and continuously matches them to see if they can trade. Your application must be implemented in C++ and you should use a modern revision of the C++ standard (e.g., C++17).

The orders that your matching engine shall receive are timestamped upon arrival. Orders are first ranked according to their price; orders of the same price are then ranked depending on the timestamp at entry.

Your application must read orders from stdin in the format described below. As your program reads the orders, it must emit any trades that result from the placement of an order. These trades shall be printed to stdout.

Once the input stream is fully consumed, your application must print all remaining orders that did not fully trade. These orders must also be printed to stdout.

Please note the streaming nature of this input and structure your program accordingly.

Input Format

Each order shall be delimitted by a new line. Each line consists of an order's OrderID, Side, Instrument, Quantity and Price, delimitted by a varying quantity of white space. The stream of orders are sequenced chronologically.

Sample Input

12345 BUY BTCUSD 5 10000
zod42 SELL BTCUSD 2 10001
13471 BUY BTCUSD 6 9971
11431 BUY ETHUSD 9 175
abe14 SELL BTCUSD 7 9800
plu401 SELL ETHUSD 5 170
45691 BUY ETHUSD 3 180

Output Format

For each trade produced by your application, your application must print a string followed by a newline. This string must being with the word TRADE and be followed by the Instrument, OrderID, ContraOrderID, Quantity, and Price of the trade.

Once the input stream is fully consumed, your application shall print all orders that remain on each side of every order book. The SELL side of each order book shall be printed first; the BUY side of each order book shall be printed last. For each side of every order book, orders shall be printed in the order in which they arrived. Note that arrival order is different from each order's price/time priority.

Please ensure that you leave exactly one line of whitespace between each portion of the requested output.

Sample Output

TRADE BTCUSD abe14 12345 5 10000
TRADE BTCUSD abe14 13471 2 9971
TRADE ETHUSD plu401 11431 5 175

zod42 SELL BTCUSD 2 10001
13471 BUY BTCUSD 4 9971
11431 BUY ETHUSD 4 175
45691 BUY ETHUSD 3 180

Submission Requirements

Please submit an archived directory containing the following:

  1. All source code and any additional tooling required to build, compile, and test your submission
  2. A README.md containing the following:
    • your name
    • instructions on how to build and run your application
    • a description of how you approached the problem
    • how long much time you spent on this project
  3. A run.sh that builds a Docker image and runs your application
    • Please do not submit precompiled artifacts; your Dockerfile must compile your source code when building the container image
  4. A test.sh that builds a Docker image and runs your tests
    • Similarly, please do not submit precompiled artifacts

It is of utmost importance that your submission is complete. All submissions lacking any of the above requirements will be rejected on the basis of being incomplete.

You should also showcase your knowledge of modern best practices in application development. Some relevant areas include developing with testings frameworks (like googletest or catch2), using automatic code formatters (like clang-format), and integrating static code analysis tooling (like clang-tidy).

Runtime Requirements

Gemini's Engine Team has provided a barebones project that includes ./run.sh, a Dockerfile, a Makefile, and a main.cpp which simply echos input. Executing ./run.sh locally must build and launch a Docker image that defaults to running your application. The ./run.sh file must accept piped input.

You are free to modify any of this project as you see fit. However, you must provide a ./run.sh that builds and runs your application in a Docker container. You are not bound to use FROM debian:10, however you must use a base image that is available in Docker Hub.

If you would like to add logging to your application please use stderr so that we can discern your log statements from the expected application output.

Runtime Example

$ cat sample_input.txt | ./run.sh
Sending build context to Docker daemon  197.1kB
Step 1/4 : FROM debian:10
 ---> 1b686a95ddbf
Step 2/4 : RUN apt-get -y update   && apt-get -y install build-essential   && apt-get clean
 ---> Using cache
 ---> 165e5b61f3e9
Step 3/4 : COPY src/ /app
 ---> 1e03b684802c
Step 4/4 : RUN cd /app && make build
 ---> Running in c930e5aaa0e9
mkdir -p build
g++ -o build/match_engine main.cpp
Removing intermediate container c930e5aaa0e9
 ---> 40ca2815137b
Successfully built 40ca2815137b
Successfully tagged gemini_interview:latest

====== Match Engine =====

TRADE BTCUSD abe14 12345 5 10000
TRADE BTCUSD abe14 13471 2 9971
TRADE ETHUSD plu401 11431 5 175

zod42 SELL BTCUSD 2 10001
13471 BUY BTCUSD 4 9971
11431 BUY ETHUSD 4 175
45691 BUY ETHUSD 3 180