Die Ressourcen sind geladen. Beförderung...

Einführung der Lead-Lag-Suite in der digitalen Währung (2)

Schriftsteller:Das Gras, Erstellt: 2024-12-18 11:16:41, Aktualisiert: 2024-12-19 15:42:52

数字货币中的Lead-Lag套利介绍(2)

Einführung in die Umzugssoftware

In dem ersten Artikel wurde vermutlich beschrieben, wie das Lead-Lag-Phänomen abgezogen wird. Hier geht es vor allem um die Überlagerung von Leads zwischen den verschiedenen Börsen. Der Grundprinzip des Lead-Lag-Phänomens besteht darin, durch die Nutzung von Preisverzögerungen zwischen den verschiedenen Börsen ("Lead-Lag-Effekt") zu profitieren, da die Marktliquidität, die Transaktionsgeschwindigkeit und die Verzögerung des Netzwerks von den einzelnen Börsen unterschiedlich sind, was dazu führt, dass die Preise der gleichen Währung an verschiedenen Börsen oft nicht synchron sind.

Wie kann man mit dem Lead-Lag-Effekt profitieren?

1. Monitoring der Preisunterschiede

Zunächst einmal müssen die Interessenten die Preisdifferenzen zwischen den verschiedenen Börsen in Echtzeit überwachen, insbesondere den Verkaufspreis und den Kaufpreis. Durch das Verfolgen des Verkaufspreises von Börse A und des Kaufpreises von Börse B kann ein Leverage-Gelegenheit angesehen werden, wenn der Verkaufspreis von Börse A niedriger ist als der Kaufpreis von Börse B. Zum Beispiel, wenn der Verkaufspreis von Börse A 10.000 USDT und der Kaufpreis von Börse B 10.100 USDT beträgt und der Preis 100 USDT unterscheidet, ist dies eine potenzielle Interessengeschäft.

2. Trans-Börsen-Ausführung

Sobald eine Leverage-Opportunität gefunden wurde, sollte der Leverageur einen Wertpapier an einer niedrigeren Börse (z. B. Börse A) kaufen und an einer höheren Börse (z. B. Börse B) verkaufen. Diese Operation kann durch API-Automatisierung durchgeführt werden, um eine schnelle Ausführung zu gewährleisten und den Preisunterschied zu maximieren. Bei der Ausführung der Transaktion müssen jedoch die Transaktionskosten (z. B. Handlungsgebühren und Gleitpunkte) sowie der Preisschlag berücksichtigt werden.

Wenn man Slippoints und Handlungsgebühren berücksichtigt, liegen die tatsächlichen Kosten für den Kauf und die Einnahmen aus dem Verkauf weit entfernt von den Erwartungen.

3. Die Fläche ist geschlossen.

Der letzte Schritt des Leverages ist das Brechen. Zum Beispiel, wenn der Kaufpreis von Börse A nach einer gewissen Zeit 10,100 USDT und der Verkaufspreis von Börse B nach 10,150 USDT beträgt und die Preisdifferenz von 100 USDT auf 50 USDT zurückgeht, wird das Verfahren automatisch zum Brechen gebracht.

Probleme und Lösungsstrategien in der Praxis

1. Keine Gelegenheit zur Börsengebung

Da es eine große Anzahl von Leverageern und Markthändlern gibt, ist der Preisunterschied zwischen den verschiedenen Börsen nicht sehr groß, sonst wird er schnell ausgeglichen. Dies ist das größte Problem mit Leverage-Handel.

Die Lösung:

  • Warten auf die natürliche Entstehung der PreisunterschiedeDer Markt für digitale Währungen ist sehr unbeständig, oft mit kurzen Preisschwankungen, und Geduld ist der beste Weg, um das Problem zu lösen.
  • Mit der Maker-Strategie: Die Initiative, auf einem Börsen-Orderbuch zu kaufen und zu verkaufen, und die ständige Anpassung der Rückzahlung, wenn der Preis ändert, wenn eine Transaktion durchgeführt wird, die andere Seite, um zu essen. Diese Prozedurgebühren sind niedriger, akzeptieren einen kleineren Differenzniveau und garantieren die erste Transaktion.
  • Sie beobachten mehr Transaktionen.Sie können sich nicht nur auf die Mainstream-Währungen konzentrieren, deren Verzinsungsmöglichkeiten in der Regel von einer großen Anzahl von Verzinslern erfasst wurden, was zu einer Verringerung der Preisdifferenz führt. Kalte und neue Aufwärtswährungen können aufgrund ihrer schlechten Liquidität zu einem größeren Preisunterschied führen und weniger Konkurrenz haben.
  • Auswahl kleiner Börsen: Kleine Börsen sind in der Regel wegen der schlechten Liquidität, der langsameren Preisanpassung, anfälliger für größere Preisunterschiede.
  • Wählen Sie eine Börse mit hohem UmfangEinige Börsen benötigen eine strenge KYC-Prüfung, wie die koreanische Upbit.

2. Zu große Unterschiede zwischen Preis- und Überwachungsdifferenzen

Es ist ein häufiges Problem, wenn die Prozedur feststellt, dass die Differenz bei der Abwicklung des Auftrages nicht so groß ist, was oft zu einem Verlust führt.

Die Lösung:

  • Optimierung von Netzwerk- und ServerstandortenDie Wahl eines Knotenpunkts in der Nähe des Servers der Börse reduziert die Verzögerung. Zum Beispiel kann die Auswahl kleiner, weniger flüssiger Börsen die Reaktionsgeschwindigkeit des Marktes verringern und somit die Vorreiterrolle einnehmen.
  • Asynchronisierung mit WebSocket: Mit Asynchronous-Code und WebSocket-Verbindung zu den Marktmärkten kann in Echtzeit Preisinformationen empfangen und schnell reagiert werden, um Verlustchancen aufgrund von Informationsverzögerungen zu vermeiden.

3. Einbeinige Transaktion

Einbeinhaltende Transaktionen zeigen, dass eine Partei die Transaktion abgeschlossen hat, während die andere Partei die Transaktion nicht abgeschlossen hat, was normalerweise bei schnellen Marktfluktuationen geschieht.

Die Lösung:

  • Ein vernünftiges Stop-Loss-Mechanismus: Wenn ein einseitiges Geschäft auftritt, kann ein Stop-Loss eingestellt werden, und ein rechtzeitiges Brechen ist ein wirksames Mittel, um das Risiko zu reduzieren.
  • Mit Marktpreisen bestellenDer Marktpreis garantiert die Transaktion, aber das Problem ist, dass die Transaktionspreise unkontrollierbar sind und möglicherweise zu Verlusten führen.

4. Einzelne Börsen sind voll

Wenn die Differenz über einen längeren Zeitraum besteht, werden die Mittel einer Börse schnell gekauft, und der Verzinsler kann nicht weiter mit der Verzinsung handeln. In diesem Fall benötigt der Verzinsler schnell Geld zu überweisen oder seine Positionen anzupassen.

Die Lösung:

  • WährungsumwandlungSie können: Geld transferieren und weiterhin mit Dividenden profitieren, indem sie die Transaktionen zwischen den Börsen nutzen. Auf diese Weise kann ein Kapitalrückstand im Binnenmarkt vermieden und die Liquidität erhöht werden.
  • Warten, bis sich die Differenz ändert: Es ist eine Option, auf die Rückkehr des Differenzpreises zu warten, wenn man die Kosten für die Abrechnung der Zeit berücksichtigt.

Demonstrationscode

Der Code ist nicht echtes Datenträger-Code und dient nur zur Demonstration, so dass die Anzahl der Datenträger, API-Zugriffsfehler, Asynchronisierungsschnelligkeit usw. nicht berücksichtigt werden.


// symbol 是套利的交易对,比如 BTC/USDT
let symbol = "BTC_USDT";
exchanges[0].SetCurrency(symbol);
exchanges[0].SetPrecision(2, 4); //设置精度
exchanges[1].SetCurrency(symbol);
exchanges[1].SetPrecision(2, 4);

// 设置手续费、滑点、开仓和平仓的利润率
let fee = 0.1 / 100;      // 0.1% 手续费
let slippage = 0.1 / 100; // 0.1% 滑点
let entryThreshold = 0.005; // 开仓阈值:价差大于0.5%时开仓
let exitThreshold = 0.001;  // 平仓阈值:价差回归到0.1%时平仓

// 每次循环执行的具体操作
function OnTick() {
    // 获取各个交易所的行情数据
    let tickers = exchanges.map(exchange => exchange.GetTicker(symbol));
    //容错处理
    if(!tickers[1] || !tickers[0]){
        return;
    }
    // 计算套利机会(基于利润率)
    // profitAB: 从交易所0买入,从交易所1卖出
    const profitAB = (tickers[1].Buy - tickers[0].Sell) / tickers[0].Sell - fee * 2 - slippage * 2;
    // profitBA: 从交易所1买入,从交易所0卖出
    const profitBA = (tickers[0].Buy - tickers[1].Sell) / tickers[1].Sell - fee * 2 - slippage * 2;

    // 打印日志
    Log(`Tickers: Exchange0 Buy: ${tickers[0].Sell}, Exchange1 Sell: ${tickers[1].Buy}, Profit AB: ${profitAB} USDT`);
    Log(`Tickers: Exchange1 Buy: ${tickers[1].Sell}, Exchange0 Sell: ${tickers[0].Buy}, Profit BA: ${profitBA} USDT`);

    // 根据利润判断是否执行套利操作
    if (profitAB > entryThreshold) {  // 当利润大于开仓阈值时开仓
        Log(`套利机会:从交易所0买入BTC,从交易所1卖出,利润:${profitAB} USDT`);
        executeArbitrage(0, 1, tickers[0].Sell, tickers[1].Buy, profitAB);  // 从交易所0买入并在交易所1卖出
    } else if (profitBA > entryThreshold) {
        Log(`套利机会:从交易所1买入BTC,从交易所0卖出,利润:${profitBA} USDT`);
        executeArbitrage(1, 0, tickers[1].Sell, tickers[0].Buy, profitBA);  // 从交易所1买入并在交易所0卖出
    } else if (profitAB < exitThreshold) {  // 如果价差回归,平仓
        Log(`平仓:从交易所0买入并在交易所1卖出的套利机会,利润已回归至平仓阈值`);
        closeArbitrage(0, 1, tickers[0].Sell, tickers[1].Buy); // 执行平仓操作
    } else if (profitBA < exitThreshold) { 
        Log(`平仓:从交易所1买入并在交易所0卖出的套利机会,利润已回归至平仓阈值`);
        closeArbitrage(1, 0, tickers[1].Sell, tickers[0].Buy); // 执行平仓操作
    } else {
        Log("没有足够的利润进行套利或平仓");
    }
}

// 执行套利交易
function executeArbitrage(buyExchangeIndex, sellExchangeIndex, buyPrice, sellPrice) {
    let buyExchange = exchanges[buyExchangeIndex];
    let sellExchange = exchanges[sellExchangeIndex];

    // 获取账户余额(假设为BTC余额)
    let accountBuy = buyExchange.GetAccount();
    let accountSell = sellExchange.GetAccount();

    //容错处理
    if(!accountBuy || !accountSell){
        return;
    }
    let amountBTC = Math.min(accountBuy.Balance / buyPrice, accountSell.Amount);

    // 假设每次交易量为 0.1 BTC
    let amount = Math.min(amountBTC, 0.1);

    // 确保交易量充足
    if (amount <= 0) {
        Log("余额不足,无法进行套利");
        return;
    }

    // 在买入交易所下单买入
    Log(`在交易所${buyExchangeIndex} 下单买入 ${amount} BTC @ ${buyPrice}`);
    buyExchange.Buy(buyPrice * (1 + slippage), amount);

    // 在卖出交易所下单卖出
    Log(`在交易所${sellExchangeIndex} 下单卖出 ${amount} BTC @ ${sellPrice}`);
    sellExchange.Sell(sellPrice * (1 - slippage), amount);
}

// 平仓操作
function closeArbitrage(buyExchangeIndex, sellExchangeIndex, buyPrice, sellPrice) {
    let buyExchange = exchanges[buyExchangeIndex];
    let sellExchange = exchanges[sellExchangeIndex];

    // 获取账户余额(假设为BTC余额)
    let accountBuy = buyExchange.GetAccount();
    let accountSell = sellExchange.GetAccount();

    //容错处理
    if(!accountBuy || !accountSell){
        return;
    }

    let amountBTC = Math.min(accountBuy.Balance / buyPrice, accountSell.Amount);
    let amount = Math.min(amountBTC, 0.1);

    // 在买入交易所吃单卖出
    Log(`在交易所${buyExchangeIndex} 平仓卖出 ${amount} BTC @ ${buyPrice}`);
    buyExchange.Sell(buyPrice * (1 - slippage), amount);

    // 在卖出交易所吃单买入
    Log(`在交易所${sellExchangeIndex} 平仓买入 ${amount} BTC @ ${sellPrice}`);
    sellExchange.Buy(sellPrice * (1 + slippage), amount);
}

// 主循环
function main() {
    while (true) {
        OnTick();
        Sleep(1000); // 每秒钟执行一次
    }
}

Zusammenfassung

Die Lead-Lag-Moving Swap ist eine Inter-Exchange-Swap-Strategie, die auf Marktverzögerungen basiert. Durch die genaue Analyse von Preisdifferenzen im Markt und die schnelle Ausführung von Transaktionen können die Swap-Anwender einen stabilen Gewinn im digitalen Währungsmarkt erzielen. Der Erfolg dieser Strategie hängt jedoch nicht nur von der Gestaltung der Strategie selbst ab, sondern erfordert auch gute Ausführung und ein sensibles Gespür für die Markttemperatur.


Mehr