dex: exact spill price handling in FillRoute
#2535
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR changes the
FillRoute
implementation to fill each successive frontier transactionally, letting us inspect the exact, actual price and compare it with the spill price. This avoids the situation in the current code where the spill price is only checked after committing to exceeding it.The current behavior is retained in one special case, however: if we haven't consumed any positions, by default we don't consider the spill price. The motivation is that the spill price is an estimate, and we haven't ruled out the possibility that there could be two very similar routes, each with an estimated price below their actual price, which could cause the spill/fill cycle to alternate between them, always avoiding doing any filling because the fill would be more than the (underestimated) price of the alternative. By default,
fill_route
will now ignore the spill price until executing at least once, to ensure that routing makes progress. Callers can opt out of this behavior withfill_route_exact
.