diff --git a/README.md b/README.md index b88c743..430c437 100644 --- a/README.md +++ b/README.md @@ -33,13 +33,13 @@ ## Overview -Smart Order Routers (SORs) are an important part of the [Genius Yield Decentralized Exchange](https://www.geniusyield.co/). +Smart Order Routers play a crutial role in the operation of the [Genius Yield Decentralized Exchange](https://www.geniusyield.co/). -SORs are off-chain agents that execute a routing algorithm that scans the Cardano blockchain -for open limit orders, matches them based on their trigger conditions, and submits -new transactions back to the ledger to perform the swap state transitions. Each Smart -Swap encodes trigger conditions that the SOR must fulfill to execute the swap. The SOR -continuously scans and analyzes the current state of the limit orders and relies on +Smart Order Routers (SORs) are off-chain agents that execute a routing algorithm that scans +the Cardano blockchain for open limit orders, matches them based on their trigger conditions, +and submits new transactions back to the ledger to perform the swap state transitions. +Each Smart Swap encodes trigger conditions that the SOR must fulfill to execute the swap. +The SOR continuously scans and analyzes the current state of the limit orders and relies on the configured matching strategy to best execute a customer’s order based on price. Specifically, the bot periodically builds a multi-asset order book consisting of one @@ -50,8 +50,8 @@ translated into transactions that will be signed and submitted by the bot. Due to the open and decentralized design of the protocol, anybody can run a Smart Order Router instance and collect a share of the fees, thus running a Smart Order Router instance -is not only contributiung to the further decentralization of the protocol, but it is also incentivized -financially. +is not only contributiung to the further decentralization of the protocol, but it is also +incentivized financially. ## Crash Course: GeniusYield DEX Orders and the Smart Order Routers @@ -62,29 +62,31 @@ benefit from customizing existing strategies or even implementing novel strategi For a more detailed description, please see the [Genius Yield Whitepaper](https://www.geniusyield.co/whitepaper.pdf?lng=en). Given a pair of tokens, an order will contain the number of tokens it offers, the price -of one unit of those offered, and the minimal amount we are forced to buy from the order. -Besides that, the order will have some life timeline and, of course, a notion of ownership +of one unit of those offered, and the minimal amount that must be bought from the order. +Besides that, the order will have optionally a lifetime and, of course, a notion of ownership related to the one that created it. For example, we could create an order offering of `10 tokenA`, with a unit price of `2 tokenB`, that is, we expect to receive `2 tokenB` per `1 tokenA`. Also, we want the minimal amount to be bought be `5 tokenA`. Clearly, the owners of this order will be -us and it's important to mention that all this information is **mandatory**, but we can avoid setting -the life timeline, meaning the order will always be available. Once we create an order, the offered -tokens will be locked on the order. +the creator, who placed the order, and it's important to keep in mind that all this information +is **mandatory**, excluding the lifetime of the order, which is optional, meaning the order won't +expire and it is going to be be available for an unlimited time. Once we create an order, the offered +tokens will be locked in the order, until it is filled or cancelled. -Given an order, two interesting "actions" can be performed over it. The owner can cancel -it and get back the locked tokens. Or anyone can _fill_ it, filling an order is just paying +Given an specific order, two interesting "actions" might be performed on it. The owner can cancel +it and get back the previously locked tokens. Or anyone can _fill_ it, filling an order is just paying the correct amount of tokens the owner of the order expects to receive related to the amount of tokens we want to buy from that order. Following the previous example, anyone could fill that order by buying from it `6 tokenA` and paying the owner `12 tokenB`. But, it isn't possible to buy, for instance, `3 tokenA` from the order because the minimal amount -was setup to `5`, except the amount of offered tokens is less than that. +was setup to `5`, except the amount of offered tokens is less than that. This makes sure that no tokens get +stuck in the contract, even if the number is lower then the minimal fill amount. -One important thing to mention that is transparent for any end user, is that there are -two kinds of fills: _complete_ and _partial_. A complete fill will buy all the offered -tokens from the order, and for the partial fill, we need to specify the amount we want -to buy from the order. For us, that will be running and probably improving this implementation -is relevant because, as we will see in a moment, we can design different matching strategies -using these two different fills. +One important thing to mention, that is actually completely transparent for the end user, +is that there are two kinds of fills: _complete_ and _partial_. A complete fill will buy all +the offered tokens from the order, and for the partial fill, we need to specify the amount we want +to buy from the order. For those of us, who will be not only running an SOR instance, but probably even improve the +matching strategy implementation, this is highly relevant since, as we will see in a moment, +it is possible to design different matching strategies using these two different type of fills. Up to this point, we quickly covered the key actions that can be performed over the orders. There shouldn't be any surprise if we mention that each action is performed by a transaction. @@ -113,17 +115,17 @@ Using the previous example we could have two cases: