From 16b655e7c8cfb2e32e6bb839373f30ad63506f9a Mon Sep 17 00:00:00 2001 From: Joel Grunbaum <joelgrun@gmail.com> Date: Sat, 08 Jan 2022 13:28:32 +0000 Subject: [PATCH] Added json parsing, protocol comprehension and began executables for algs --- book.cpp | 255 ++++++++++++++++++++++++++------------------------ 1 files changed, 134 insertions(+), 121 deletions(-) diff --git a/book.cpp b/book.cpp index 9cb14e7..4702e4d 100644 --- a/book.cpp +++ b/book.cpp @@ -1,95 +1,84 @@ #include "book.hpp" +#include <algorithm> #include <chrono> #include <cstddef> #include <iostream> -Order::Order(double price, OrderSideEnum side, int volume, - std::chrono::nanoseconds timestamp, std::string id) +namespace book +{ +Order::Order(double price, OrderSideEnum side, int volume, double timestamp, + std::string id) : price{price}, side{side}, remaining_volume{volume}, - filled_volume(0), timestamp{timestamp}, id{id} {} + filled_volume(0), timestamp{timestamp}, id{id} +{ +} -Level::Level(Order &order) +Level::Level(Order& order) : price{order.price}, volume(order.remaining_volume), side{order.side}, - timestamp{order.timestamp}, id{order.id} {} - -bool operator<(const Level &a, const Level &b) { - if (a.price < b.price) - return true; - else if (a.price == b.price && (a.timestamp.count() > b.timestamp.count())) - return true; - else - return false; + timestamp{order.timestamp}, id{order.id} +{ } -bool operator>(const Level &a, const Level &b) { - if (a.price > b.price) - return true; - else if (a.price == b.price && (a.timestamp.count() > b.timestamp.count())) - return true; - else - return false; +bool operator<(const Level& a, const Level& b) +{ + if (a.price < b.price) + return true; + else if (a.price == b.price && (a.timestamp > b.timestamp)) + return true; + else + return false; } -bool operator<=(const Level &a, const Level &b) { - if (a.price <= b.price) - return true; - else if (a.price == b.price && (a.timestamp.count() >= b.timestamp.count())) - return true; - else - return false; +bool operator>(const Level& a, const Level& b) +{ + if (a.price > b.price) + return true; + else if (a.price == b.price && (a.timestamp > b.timestamp)) + return true; + else + return false; } -bool operator>=(const Level &a, const Level &b) { - if (a.price >= b.price) - return true; - else if (a.price == b.price && (a.timestamp.count() >= b.timestamp.count())) - return true; - else - return false; +bool operator<=(const Level& a, const Level& b) +{ + if (a.price <= b.price) + return true; + else if (a.price == b.price && (a.timestamp >= b.timestamp)) + return true; + else + return false; } -bool operator==(const Level &a, const Level &b) { - if (a.price == b.price && (a.timestamp.count() == b.timestamp.count())) - return true; - else - return false; +bool operator>=(const Level& a, const Level& b) +{ + if (a.price >= b.price) + return true; + else if (a.price == b.price && (a.timestamp >= b.timestamp)) + return true; + else + return false; +} + +bool operator==(const Level& a, const Level& b) +{ + if (a.price == b.price && (a.timestamp == b.timestamp)) + return true; + else + return false; } std::ostream& operator<<(std::ostream& out, const Level& a) { - return out << "Price: " << a.price << ", volume: " << a.volume << ", time: " << a.timestamp.count() << ", id: " << a.id; -} - -template<class T> -void Side<T>::deleteLevel(std::string orderId) -{ - for (auto i = this->c.begin(); i != this->c.end();) { - if (*i.id == orderId) { - this->c.erase(i); - std::make_heap(this->c.begin(), this->c.end(), this->comp); - } - } -} - -template<class T> -void Side<T>::topRemoveVolume(int volume) { this->c[0].volume -= volume; } - -template<class T> -void Side<T>::printTop(std::size_t num) -{ - std::vector<Level> copy(this->c); - std::sort(copy.begin(), copy.end(), this->comp); - if (copy.size() && copy[0].side == Buy) - std::reverse(copy.begin(), copy.end()); - for (std::size_t i = 0; i < copy.size() && i < num; i++) { - std::cout << copy[i] << std::endl; - } + return out << "Price: " << a.price << ", volume: " << a.volume + << ", time: " << a.timestamp << ", id: " << a.id; } Book::Book() : bidSide(), askSide(), productType(TEST), product("a"), stationId("b"), unit("c"), expiry(std::chrono::nanoseconds(0)), aggFee(1), pasFee(-1), - broFee(2) {} + broFee(2) +{ +} Book::Book(ProductTypeEnum productType, std::string product, std::string stationId, std::string unit, @@ -97,65 +86,89 @@ double broFee) : bidSide{}, askSide{}, productType{productType}, product(product), stationId(stationId), unit(unit), expiry(expiry), aggFee(aggFee), - pasFee(pasFee), broFee(broFee) {} + pasFee(pasFee), broFee(broFee) +{ +} -void Book::ask(Order &order) { - while (this->bidSide.size() && this->bidSide.top().price >= order.price) { - if (this->bidSide.top().volume > order.remaining_volume) { - int temp = this->bidSide.top().volume; - order.filled_volume += temp; - this->bidSide.topRemoveVolume(order.remaining_volume); - order.remaining_volume -= temp; - break; - } else { - order.remaining_volume -= this->bidSide.top().volume; - order.filled_volume += this->bidSide.top().volume; - this->bidSide.pop(); +void Book::ask(Order& order) +{ + while (this->bidSide.size() && this->bidSide[0].price >= order.price) { + if (this->bidSide[0].volume > order.remaining_volume) { + int temp = this->bidSide[0].volume; + order.filled_volume += temp; + this->bidSide.front().volume -= order.remaining_volume; + order.remaining_volume -= temp; + break; + } else { + order.remaining_volume -= this->bidSide[0].volume; + order.filled_volume += this->bidSide[0].volume; + this->bidSide.erase(this->bidSide.begin()); + std::make_heap(this->bidSide.begin(), this->bidSide.end(), + std::less<Level>()); + } } - } - if (order.remaining_volume > 0) { - this->askSide.emplace(order); - } -} - -void Book::bid(Order &order) { - while (this->askSide.size() && this->askSide.top().price <= order.price) { - if (this->askSide.top().volume > order.remaining_volume) { - int temp = this->askSide.top().volume; - order.filled_volume += temp; - this->askSide.topRemoveVolume(order.remaining_volume); - order.remaining_volume -= temp; - break; - } else { - order.remaining_volume -= this->askSide.top().volume; - order.filled_volume += this->askSide.top().volume; - this->askSide.pop(); + if (order.remaining_volume > 0) { + this->askSide.emplace(this->askSide.begin(), order); + std::make_heap(this->askSide.begin(), this->askSide.end(), + std::greater<Level>()); } - } - if (order.remaining_volume > 0) { - this->bidSide.emplace(order); - } } -void Book::printBook(std::size_t numOrders) { - std::cout << "Sell side: " << this->askSide.size() << std::endl; - this->askSide.printTop(numOrders); - std::cout << "Buy side: " << this->bidSide.size() << std::endl; - this->bidSide.printTop(numOrders); +void Book::bid(Order& order) +{ + while (this->askSide.size() && this->askSide[0].price <= order.price) { + if (this->askSide[0].volume > order.remaining_volume) { + int temp = this->askSide.front().volume; + order.filled_volume += temp; + this->askSide.front().volume -= order.remaining_volume; + order.remaining_volume -= temp; + break; + } else { + order.remaining_volume -= this->askSide[0].volume; + order.filled_volume += this->askSide[0].volume; + this->askSide.erase(this->askSide.begin()); + std::make_heap(this->askSide.begin(), this->askSide.end(), + std::greater<Level>()); + } + } + if (order.remaining_volume > 0) { + this->bidSide.emplace(this->bidSide.begin(), order); + std::make_heap(this->bidSide.begin(), this->bidSide.end(), + std::less<Level>()); + } } -Book testBook(int orders, bool printBook) { - Book b = Book(); - std::chrono::nanoseconds time(1); - for (int i = 1; i < orders; i++) { - Order t(i, Buy, 10, time++, "a"); - b.bid(t); - } - for (int i = orders + 1; i < 2 * orders; i++) { - Order t(i, Sell, 10, time++, "b"); - b.ask(t); - } - if (printBook) - b.printBook(orders - 1); - return b; +void Book::printBook(std::size_t numOrders) +{ + std::cout << "Sell side: " << this->askSide.size() << std::endl; + std::vector<Level> askCopy(this->askSide); + int count = 0; + std::sort(askCopy.begin(), askCopy.end()); + for (auto i = askCopy.rbegin(); i != askCopy.rend() && count < numOrders; i++, count++) { + std::cout << *i << std::endl; + } + std::cout << "Buy side: " << this->bidSide.size() << std::endl; + std::vector<Level> bidCopy(this->bidSide); + count = 0; + std::sort(bidCopy.begin(), bidCopy.end()); + for (auto i = bidCopy.rbegin(); i != bidCopy.rend() && count < numOrders; i++, count++) { + std::cout << *i << std::endl; + } + } + +Book testBook(int orders, bool printBook) +{ + Book b = Book(); + double time(1); + for (int i = 1; i < orders; i++) { + Order t(i, Buy, 10, time++, "a"); + b.bid(t); + } + for (int i = orders + 1; i < 2 * orders; i++) { + Order t(i, Sell, 10, time++, "b"); + b.ask(t); + } + if (printBook) b.printBook(orders - 1); + return b; } +} // namespace book -- Gitblit v1.9.3