mirror of
https://github.com/c9s/bbgo.git
synced 2024-11-14 02:53:50 +00:00
xmaker: rewrite maker order submission logics and integrate metrics
This commit is contained in:
parent
c76a80da6a
commit
9a1d9ae27b
|
@ -2,11 +2,17 @@ package xmaker
|
||||||
|
|
||||||
import "github.com/prometheus/client_golang/prometheus"
|
import "github.com/prometheus/client_golang/prometheus"
|
||||||
|
|
||||||
var openOrderExposureInUsdMetrics = prometheus.NewGaugeVec(
|
var openOrderBidExposureInUsdMetrics = prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
Name: "xmaker_open_order_exposure_in_usd",
|
Name: "xmaker_open_order_bid_exposure_in_usd",
|
||||||
Help: "",
|
Help: "",
|
||||||
}, []string{"strategy_type", "strategy_id", "exchange", "symbol", "side"})
|
}, []string{"strategy_type", "strategy_id", "exchange", "symbol"})
|
||||||
|
|
||||||
|
var openOrderAskExposureInUsdMetrics = prometheus.NewGaugeVec(
|
||||||
|
prometheus.GaugeOpts{
|
||||||
|
Name: "xmaker_open_order_ask_exposure_in_usd",
|
||||||
|
Help: "",
|
||||||
|
}, []string{"strategy_type", "strategy_id", "exchange", "symbol"})
|
||||||
|
|
||||||
var makerBestBidPriceMetrics = prometheus.NewGaugeVec(
|
var makerBestBidPriceMetrics = prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
|
@ -28,7 +34,8 @@ var numOfLayersMetrics = prometheus.NewGaugeVec(
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
prometheus.MustRegister(
|
prometheus.MustRegister(
|
||||||
openOrderExposureInUsdMetrics,
|
openOrderBidExposureInUsdMetrics,
|
||||||
|
openOrderAskExposureInUsdMetrics,
|
||||||
makerBestBidPriceMetrics,
|
makerBestBidPriceMetrics,
|
||||||
makerBestAskPriceMetrics,
|
makerBestAskPriceMetrics,
|
||||||
numOfLayersMetrics,
|
numOfLayersMetrics,
|
||||||
|
|
|
@ -7,6 +7,7 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
"golang.org/x/time/rate"
|
"golang.org/x/time/rate"
|
||||||
|
|
||||||
|
@ -384,6 +385,16 @@ func (s *Strategy) updateQuote(ctx context.Context, orderExecutionRouter bbgo.Or
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
labels := prometheus.Labels{
|
||||||
|
"strategy_type": ID,
|
||||||
|
"strategy_id": s.InstanceID(),
|
||||||
|
"exchange": s.MakerExchange,
|
||||||
|
"symbol": s.Symbol,
|
||||||
|
}
|
||||||
|
|
||||||
|
bidExposureInUsd := fixedpoint.Zero
|
||||||
|
askExposureInUsd := fixedpoint.Zero
|
||||||
|
|
||||||
bidPrice := bestBidPrice
|
bidPrice := bestBidPrice
|
||||||
askPrice := bestAskPrice
|
askPrice := bestAskPrice
|
||||||
for i := 0; i < s.NumLayers; i++ {
|
for i := 0; i < s.NumLayers; i++ {
|
||||||
|
@ -417,6 +428,8 @@ func (s *Strategy) updateQuote(ctx context.Context, orderExecutionRouter bbgo.Or
|
||||||
Mul(s.makerMarket.TickSize)))
|
Mul(s.makerMarket.TickSize)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
makerBestBidPriceMetrics.With(labels).Set(bidPrice.Float64())
|
||||||
|
|
||||||
if makerQuota.QuoteAsset.Lock(bidQuantity.Mul(bidPrice)) && hedgeQuota.BaseAsset.Lock(bidQuantity) {
|
if makerQuota.QuoteAsset.Lock(bidQuantity.Mul(bidPrice)) && hedgeQuota.BaseAsset.Lock(bidQuantity) {
|
||||||
// if we bought, then we need to sell the base from the hedge session
|
// if we bought, then we need to sell the base from the hedge session
|
||||||
submitOrders = append(submitOrders, types.SubmitOrder{
|
submitOrders = append(submitOrders, types.SubmitOrder{
|
||||||
|
@ -431,6 +444,7 @@ func (s *Strategy) updateQuote(ctx context.Context, orderExecutionRouter bbgo.Or
|
||||||
|
|
||||||
makerQuota.Commit()
|
makerQuota.Commit()
|
||||||
hedgeQuota.Commit()
|
hedgeQuota.Commit()
|
||||||
|
bidExposureInUsd = bidExposureInUsd.Add(bidQuantity.Mul(bidPrice))
|
||||||
} else {
|
} else {
|
||||||
makerQuota.Rollback()
|
makerQuota.Rollback()
|
||||||
hedgeQuota.Rollback()
|
hedgeQuota.Rollback()
|
||||||
|
@ -470,7 +484,10 @@ func (s *Strategy) updateQuote(ctx context.Context, orderExecutionRouter bbgo.Or
|
||||||
askPrice = askPrice.Add(pips.Mul(fixedpoint.NewFromInt(int64(i)).Mul(s.makerMarket.TickSize)))
|
askPrice = askPrice.Add(pips.Mul(fixedpoint.NewFromInt(int64(i)).Mul(s.makerMarket.TickSize)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
makerBestAskPriceMetrics.With(labels).Set(askPrice.Float64())
|
||||||
|
|
||||||
if makerQuota.BaseAsset.Lock(askQuantity) && hedgeQuota.QuoteAsset.Lock(askQuantity.Mul(askPrice)) {
|
if makerQuota.BaseAsset.Lock(askQuantity) && hedgeQuota.QuoteAsset.Lock(askQuantity.Mul(askPrice)) {
|
||||||
|
|
||||||
// if we bought, then we need to sell the base from the hedge session
|
// if we bought, then we need to sell the base from the hedge session
|
||||||
submitOrders = append(submitOrders, types.SubmitOrder{
|
submitOrders = append(submitOrders, types.SubmitOrder{
|
||||||
Symbol: s.Symbol,
|
Symbol: s.Symbol,
|
||||||
|
@ -484,6 +501,8 @@ func (s *Strategy) updateQuote(ctx context.Context, orderExecutionRouter bbgo.Or
|
||||||
})
|
})
|
||||||
makerQuota.Commit()
|
makerQuota.Commit()
|
||||||
hedgeQuota.Commit()
|
hedgeQuota.Commit()
|
||||||
|
|
||||||
|
askExposureInUsd = askExposureInUsd.Add(askQuantity.Mul(askPrice))
|
||||||
} else {
|
} else {
|
||||||
makerQuota.Rollback()
|
makerQuota.Rollback()
|
||||||
hedgeQuota.Rollback()
|
hedgeQuota.Rollback()
|
||||||
|
@ -500,14 +519,28 @@ func (s *Strategy) updateQuote(ctx context.Context, orderExecutionRouter bbgo.Or
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
makerOrders, err := orderExecutionRouter.SubmitOrdersTo(ctx, s.MakerExchange, submitOrders...)
|
formattedOrders, err := s.makerSession.FormatOrders(submitOrders)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.WithError(err).Errorf("order error: %s", err.Error())
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
s.activeMakerOrders.Add(makerOrders...)
|
orderCreateCallback := func(createdOrder types.Order) {
|
||||||
s.orderStore.Add(makerOrders...)
|
s.orderStore.Add(createdOrder)
|
||||||
|
s.activeMakerOrders.Add(createdOrder)
|
||||||
|
}
|
||||||
|
|
||||||
|
defer s.tradeCollector.Process()
|
||||||
|
|
||||||
|
createdOrders, errIdx, err := bbgo.BatchPlaceOrder(ctx, s.makerSession.Exchange, orderCreateCallback, formattedOrders...)
|
||||||
|
if err != nil {
|
||||||
|
log.WithError(err).Errorf("unable to place maker orders: %+v", formattedOrders)
|
||||||
|
}
|
||||||
|
|
||||||
|
openOrderBidExposureInUsdMetrics.With(labels).Set(bidExposureInUsd.Float64())
|
||||||
|
openOrderAskExposureInUsdMetrics.With(labels).Set(askExposureInUsd.Float64())
|
||||||
|
|
||||||
|
_ = errIdx
|
||||||
|
_ = createdOrders
|
||||||
}
|
}
|
||||||
|
|
||||||
var lastPriceModifier = fixedpoint.NewFromFloat(1.001)
|
var lastPriceModifier = fixedpoint.NewFromFloat(1.001)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user