diff --git a/protocol/0012-POSR-position_resolution.md b/protocol/0012-POSR-position_resolution.md index ab70da7c0..009e1699d 100644 --- a/protocol/0012-POSR-position_resolution.md +++ b/protocol/0012-POSR-position_resolution.md @@ -31,15 +31,16 @@ - When calculating the available volume, the full remaining size of iceberg orders should be considered. (0012-POSR-019) - When calculating the available volume, volume outside price monitoring bounds should be considered. (0012-POSR-020) -- When calculating the available volume, volume outside the liquidity price range should not be considered. (0012-POSR-021) +- When calculating the available volume, volume outside the disposal price range should not be considered. (0012-POSR-033) - Given a highly liquid market, if the network’s position is greater than `full disposal size`. The network must attempt to dispose `position * disposal fraction` at the next disposal step. (0012-POSR-022) - Given a highly liquid market, if the network’s position is less than or equal to `full disposal size`. The network must attempt to dispose of its full position at the next disposal step. (0012-POSR-023) - Given a highly liquid market, if the network’s `disposal fraction<1` and `full disposal size`=0, the network must still eventually dispose of its full position. (0012-POSR-024) - The network must never dispose more than `available volume * max fraction of book side within liquidity bounds consumed` in a single order. (0012-POSR-025) - A network disposal order which generates trades must not affect the mark price. (0012-POSR-026) -- A network disposal order can not cross with orders outside the liquidity price range. (0012-POSR-027) +- A network disposal order can not cross with orders outside the disposal price range. (0012-POSR-031) - A network disposal order will not cross with orders outside price monitoring bounds (internally has to behave like an IOC at one tick inside the price monitoring bound). Hence a network disposal cannot trade at a price outside the tightest price monitoring and it won't ever trigger a price monitoring auction. (0012-POSR-030) - A network disposal order which crosses multiple orders should generate multiple atomic trades. (0012-POSR-029) +- A network disposal order which crosses with volume implied by an vAMM should trade with the vAMM volume. (0012-POSR-032) ### Network Profit and Loss @@ -110,15 +111,21 @@ Currently only one liquidation strategy is supported and its defined by the foll - `disposal time step` (min: `1s`, max: `1h`): network attempts to unload its position in a given market every time it goes out of auction and then every `disposal time step` seconds as long as market is not in auction mode and while the network's position is not equal to `0`, - `disposal fraction` (min: `0.01`, max: `1`): fraction of network's current open volume that it will try to reduce in a single disposal attempt, - `full disposal size` (min: `0`, max: `max int`): once net absolute value of network's open volume is at or below that value, the network will attempt to dispose the remaining amount in one go, -- `max fraction of book side within liquidity bounds consumed` (min: `0`, max: `1`): once the network chooses the size of its order (`s_candidate`) the effective size will be calculated as `s_effective=min(m*N, s_candidate)`, where `N` is the sum of volume (on the side of the book with which the network's order will be matching) that falls within the range implied by the `market.liquidity.priceRange` [parameter](./0044-LIME-lp_mechanics.md#market-parameters) and `m` is the `max fraction of book side within liquidity bounds consumed`. +- `disposal slippage range` (decimal `>0` with default of `0.1` which is interpreted as `10%`, existing markets to default to their current SLA range). Just like [SLA range](./0044-LIME-lp_mechanics.md) these are taken from `mid_price` during continuous trading or indicative uncrossing price during auctions so the lower bound becomes `max(0,price x (1-range)` and upper bound `price x (1+range)`. +- `max fraction of book side within bounds consumed` (min: `0`, max: `1`): once the network chooses the size of its order (`s_candidate`) the effective size will be calculated as `s_effective=min(m*N, s_candidate)`, where `N` is the sum of volume (on the side of the book with which the network's order will be matching) that falls within the range implied by the `disposal slippage range` and `m` is the `max fraction of book side within liquidity bounds consumed`. +When vAMMs are implemented and provide liquidity then volume implied by vAMMs that lies within the relevant range must be included in the calculation. + +Assume the price range implied by the `disposal slippage range` is `[a, b]`. +Assume the the tightest price monitoring bound has lower bound plus one tick of `c` and upper bound minus one tick of `d`. +Once the network has worked out a size of its immediate or cancel limit order it sets its price to `max(a,c)` if it's a sell order or `min(b,d)` if it's a buy order, and it submits the order. -Assume the price range implied by the `market.liquidity.priceRange` is `[a, b]`. Once the network has worked out a size of its immediate or cancel limit order it sets it's price to `a` if it's a sell order or `b` if it's a buy order, and it submits the order. Note that setting: - `disposal time step` = `0s`, - `disposal fraction` = `1`, - `full disposal size` = `max int`, +- `disposal slippage range` = `10`, - `max fraction of book side within liquidity bounds consumed` = `1` is closest to reproducing the legacy setup where party would get liquidated immediately (with a difference that closeout now happens immediately even if there's not enough volume on the book to fully absorb it) hence the above values should be used when migrating existing markets to a new version. For all new markets these values should be specified explicitly. diff --git a/protocol/features.json b/protocol/features.json index 5f4ed956d..dbbb2a62c 100644 --- a/protocol/features.json +++ b/protocol/features.json @@ -370,6 +370,14 @@ "0003-NP-LIMI-007" ] }, + "Explicit liquidation range": { + "milestone": "colosseo", + "acs": [ + "0012-POSR-031", + "0012-POSR-032", + "0012-POSR-033" + ] + }, "Teams": { "milestone": "colosseo", "acs": ["0083-RFPR-068"] diff --git a/protocol/palazzo-features.json b/protocol/palazzo-features.json index 2e4a17cd8..0f704e3cd 100644 --- a/protocol/palazzo-features.json +++ b/protocol/palazzo-features.json @@ -235,13 +235,11 @@ "0012-POSR-018", "0012-POSR-019", "0012-POSR-020", - "0012-POSR-021", "0012-POSR-022", "0012-POSR-023", "0012-POSR-024", "0012-POSR-025", "0012-POSR-026", - "0012-POSR-027", "0012-POSR-029", "0003-MTMK-015", "0003-MTMK-016", diff --git a/wordlist.txt b/wordlist.txt index 8001e5979..81a3aab42 100644 --- a/wordlist.txt +++ b/wordlist.txt @@ -317,6 +317,8 @@ UTC validator validator's validators +vAMM +vAMMs vega vegaprotocol vegatools