1#include <xrpld/app/paths/AMMLiquidity.h>
2#include <xrpld/app/paths/AMMOffer.h>
4#include <xrpl/protocol/QualityFunction.h>
8template <
typename TIn,
typename TOut>
11 TAmounts<TIn, TOut>
const& amounts,
12 TAmounts<TIn, TOut>
const& balances,
13 Quality
const& quality)
14 : ammLiquidity_(ammLiquidity)
22template <
typename TIn,
typename TOut>
26 return ammLiquidity_.issueIn();
29template <
typename TIn,
typename TOut>
33 return ammLiquidity_.ammAccount();
36template <
typename TIn,
typename TOut>
37TAmounts<TIn, TOut>
const&
43template <
typename TIn,
typename TOut>
48 if (consumed.in > amounts_.in || consumed.out > amounts_.out)
49 Throw<std::logic_error>(
"Invalid consumed AMM offer.");
56 ammLiquidity_.context().setAMMUsed();
59template <
typename TIn,
typename TOut>
62 TAmounts<TIn, TOut>
const& offerAmount,
72 if (ammLiquidity_.multiPath())
76 return quality().ceil_out_strict(offerAmount, limit, roundUp);
81 return {
swapAssetOut(balances_, limit, ammLiquidity_.tradingFee()), limit};
84template <
typename TIn,
typename TOut>
90 if (ammLiquidity_.multiPath())
93 rules && rules->enabled(fixReducedOffersV2))
94 return quality().ceil_in_strict(offerAmount, limit, roundUp);
96 return quality().ceil_in(offerAmount, limit);
98 return {limit,
swapAssetIn(balances_, limit, ammLiquidity_.tradingFee())};
101template <
typename TIn,
typename TOut>
105 if (ammLiquidity_.multiPath())
110template <
typename TIn,
typename TOut>
114 if (consumed.in > amounts_.in || consumed.out > amounts_.out)
116 JLOG(j.
error()) <<
"AMMOffer::checkInvariant failed: consumed " <<
to_string(consumed.in)
123 Number const product = balances_.in * balances_.out;
124 auto const newBalances =
125 TAmounts<TIn, TOut>{balances_.in + consumed.in, balances_.out - consumed.out};
126 Number const newProduct = newBalances.in * newBalances.out;
131 JLOG(j.
error()) <<
"AMMOffer::checkInvariant failed: balances " <<
to_string(balances_.in)
132 <<
" " <<
to_string(balances_.out) <<
" new balances "
134 <<
" product/newProduct " << product <<
" " << newProduct <<
" diff "
A generic endpoint for log messages.
AMMLiquidity class provides AMM offers to BookStep class.
Represents synthetic AMM offer in BookStep.
AMMOffer(AMMLiquidity< TIn, TOut > const &ammLiquidity, TAmounts< TIn, TOut > const &amounts, TAmounts< TIn, TOut > const &balances, Quality const &quality)
void consume(ApplyView &view, TAmounts< TIn, TOut > const &consumed)
TAmounts< TIn, TOut > const & amount() const
QualityFunction getQualityFunc() const
TAmounts< TIn, TOut > limitOut(TAmounts< TIn, TOut > const &offerAmount, TOut const &limit, bool roundUp) const
Limit out of the provided offer.
Issue const & issueIn() const
bool checkInvariant(TAmounts< TIn, TOut > const &consumed, beast::Journal j) const
Check the new pool product is greater or equal to the old pool product or if decreases then within so...
AccountID const & owner() const
TAmounts< TIn, TOut > limitIn(TAmounts< TIn, TOut > const &offerAmount, TIn const &limit, bool roundUp) const
Limit in of the provided offer.
Writeable view to a ledger, for applying a transaction.
A currency issued by an account.
Number is a floating point type that can represent a wide range of values.
Average quality of a path as a function of out: q(out) = m * out + b, where m = -1 / poolGets,...
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
std::string to_string(base_uint< Bits, Tag > const &a)
std::optional< Rules > const & getCurrentTransactionRules()
TOut swapAssetIn(TAmounts< TIn, TOut > const &pool, TIn const &assetIn, std::uint16_t tfee)
AMM pool invariant - the product (A * B) after swap in/out has to remain at least the same: (A + in) ...
TIn swapAssetOut(TAmounts< TIn, TOut > const &pool, TOut const &assetOut, std::uint16_t tfee)
Swap assetOut out of the pool and swap in a proportional amount of the other asset.
bool withinRelativeDistance(Quality const &calcQuality, Quality const &reqQuality, Number const &dist)
Check if the relative distance between the qualities is within the requested distance.