資源の読み込みに... 荷物...

多取引所・スポット・スプレッド・アービトラージ・戦略 論理共有

作者: リン・ハーン発明者 量化 - 微かな夢, 作成日: 2022-07-12 17:20:06, 更新日: 2024-12-02 21:43:21

Multi-Exchange Spot Spread Arbitrage Strategy Logic Sharing

戦略の原則

流動性上の理由により,市場に大量にスクラッシュと引き寄せが起こると,必然的に大きな価格変動があり,取引所で瞬間の価格差が形成され,戦略は低価格で購入し高価格で販売するプロセスを完了するために,迅速な取引が実行されるこれらの瞬間を捕捉することです. 取引所間の瞬間の価格差です. 取引所が増えるほど,クロスオーバー後に形成される価格差の機会が増えます. 取引所が成長するにつれて,取引所が成長します.

戦略の基本論理
  1. 複数の取引所の市場情報を同時に取得するには,取得された市場の遅延を減らすために同時に取得する必要があります.マルチ-エクスチェンジ 同期プラグイン
  2. すべての交換オーダーのオードとオードを組み合わせて,組み合わせたオーダー情報を得ます.RealPriceは処理手数料を引いた価格です.
function createOrders(depths, askOrders, bidOrders) {
    let asksIndex = 0;
    let bidIndex = 0;
    for (let i = 0; i < depths.length; i++) {
        let exchangeTariff = getExchangeTariff(i);
        let asks = depths[i].Asks;
        let bids = depths[i].Bids;
        for (let j = 0; j < Math.min(asks.length, bids.length, 20); j++) {
            if (asks[j].Amount >= minTakerAmount) {
                askOrders[asksIndex] = {
                    "Price": asks[j].Price,
                    "Amount": asks[j].Amount,
                    "Fee": asks[j].Price * exchangeTariff,
                    "RealPrice": asks[j].Price * (1 + exchangeTariff),
                    "Index": i,
                };
                asksIndex++;
            }
            if (bids[j].Amount >= minTakerAmount) {
                bidOrders[bidIndex] = {
                    "Price": bids[j].Price,
                    "Amount": bids[j].Amount,
                    "Fee": bids[j].Price * exchangeTariff,
                    "RealPrice": bids[j].Price * (1 - exchangeTariff),
                    "Index": i,
                };
                bidIndex++;
            }
        }
    }
    askOrders.sort(function (a, b) {
        return a.RealPrice - b.RealPrice;
    });
    bidOrders.sort(function (a, b) {
        return b.RealPrice - a.RealPrice;
    });
}
  1. 市場情報を組み合わせて最高のアービトラージ・スプレッドを計算する.我々は,注文を取っているので,つまり,最も低い価格から購入し,最も高い価格から販売し,限り, bod.RealPrice > ask.RealPrice,利益のための余地があります.
function getArbitrageOrders(askOrders, bidOrders) {
    let ret = [];
    for (let i = 0; i < askOrders.length; i++) {
        for (let j = 0; j < bidOrders.length; j++) {
            let bidOrder = bidOrders[j];
            let askOrder = askOrders[i];
            if (bidOrder.Index === askOrder.Index) {
                continue
            }
            let minMigrateDiffPrice = ((askOrder.Price + bidOrder.Price) / 2 * minMigrateDiffPricePercent / 100);
            if (bidOrder.RealPrice - askOrder.RealPrice > minMigrateDiffPrice) {
                ret.push({
                    "Ask": askOrder,
                    "Bid": bidOrder,
                })
            }
        }
    }
    if (ret.length === 0) {
        ret.push({
            "Ask": askOrders[0],
            "Bid": bidOrders[0],
        });
    }
    //Sort by best spread
    ret.sort((a, b) => {
        return (b.Bid.RealPrice - b.Ask.RealPrice) - (a.Bid.RealPrice - a.Ask.RealPrice);
    });
    return ret;
}
  1. この時点で,我々は,市場におけるアービトラージ・スプレッドに関する情報を入手したので,取引を実行するか,取引する金額を選択する方法についていくつかの判断点があります:
    • 現金残高資産
    • スプレッドの大きさ (スプレッドが小さすぎる場合,通貨の量だけがバランスされ,スプレッドが十分に大きい場合,取引の数が最大化されます)
    • 待機中の注文数
    var askOrder = arbitrageOrder.Ask;
    var bidOrder = arbitrageOrder.Bid;
    var perAmountFee = arbitrageOrder.Ask.Fee + arbitrageOrder.Bid.Fee;
    var minRealDiffPrice = (askOrder.Price + bidOrder.Price) / 2 * minDiffPricePercent / 100;
    var minMigrateDiffPrice = ((askOrder.Price + bidOrder.Price) / 2 * minMigrateDiffPricePercent / 100);
    var curRealDiffPrice = arbitrageOrder.Bid.RealPrice - arbitrageOrder.Ask.RealPrice;
    var buyExchange = exchanges[arbitrageOrder.Ask.Index];
    var sellExchange = exchanges[arbitrageOrder.Bid.Index];
    var buySellAmount = 0;
    if (curRealDiffPrice > minRealDiffPrice) {
        buySellAmount = math.min(
            bidOrder.Amount,
            askOrder.Amount,
            maxTakerAmount,
            runningInfo.Accounts[bidOrder.Index].CurStocks,
            runningInfo.Accounts[askOrder.Index].CurBalance / askOrder.Price
        );
    } else if (bidOrder.Index !== askOrder.Index) {
        if (migrateCoinEx == -1) {
            if (curRealDiffPrice > minMigrateDiffPrice && runningInfo.Accounts[bidOrder.Index].CurStocks - runningInfo.Accounts[askOrder.Index].CurStocks > maxAmountDeviation) {
                buySellAmount = math.min(
                    bidOrder.Amount,
                    askOrder.Amount,
                    maxTakerAmount,
                    runningInfo.Accounts[bidOrder.Index].CurStocks,
                    runningInfo.Accounts[askOrder.Index].CurBalance / askOrder.Price,
                    runningInfo.Accounts[bidOrder.Index].CurStocks - ((runningInfo.Accounts[bidOrder.Index].CurStocks + runningInfo.Accounts[askOrder.Index].CurStocks) / 2)
                );
                if (buySellAmount >= minTakerAmount) {
                    Log("Start exchange balancing!");
                }
            }
        } else if (migrateCoinEx == askOrder.Index) {
            if (curRealDiffPrice > minMigrateDiffPrice && runningInfo.Accounts[bidOrder.Index].CurStocks > 0) {
                buySellAmount = math.min(
                    bidOrder.Amount,
                    askOrder.Amount,
                    maxTakerAmount,
                    runningInfo.Accounts[bidOrder.Index].CurStocks,
                    runningInfo.Accounts[askOrder.Index].CurBalance / askOrder.Price
                );
                if (buySellAmount >= minTakerAmount) {
                    Log("Initiate currency migration:", exchanges[bidOrder.Index].GetName(), "-->", exchanges[askOrder.Index].GetName());
                }
            }
        }
    }
  1. 配置される注文の数を計算した後,取引は実行できます. 戦略は,直接スリップを追加し,同時に注文を取る方法を採用します.
            var buyWait = buyExchange.Go("Buy", _N(askOrder.Price * (1.01), pricePrecision), buySellAmount);
            var sellWait = sellExchange.Go("Sell", _N(bidOrder.Price * (0.99), pricePrecision), buySellAmount);
            var startWaitTime = new Date().getTime()
            Sleep(3000);
            var buyOrder = buyWait.wait()
            var sellOrder = sellWait.wait()
  1. 失敗した注文のストップ損失を処理する 論理が残ります
戦略の実際の利益

Multi-Exchange Spot Spread Arbitrage Strategy Logic Sharing Multi-Exchange Spot Spread Arbitrage Strategy Logic Sharing Multi-Exchange Spot Spread Arbitrage Strategy Logic Sharing

現在のリアルボット表示,コアロジックは変わらない,複数の通貨をサポートするために最適化

https://www.fmz.com/robot/464965

最後に,ラオキウの量的な交換のコミュニケーションに参加してください.https://t.me/laoqiu_arbitrage


関連コンテンツ

もっと見る