Binance Strategie 2: Höhe und Tiefen entfernen

Schriftsteller:Quantifizierung der Zonen, Datum: 2020-04-09 21:44:22
Tags:Binance

Danke für die öffentliche Strategie von FMZ, danke für die Unterstützung der Garde! Ich habe zwei Änderungen selbst vorgenommen: 1, da viele Freunde standardmäßig 10-mal und 20-mal Hebel haben, und die Strategie ist ein ganzes Lagermodus, eine Börse wird gelöscht. 2. Wenn es in der Währungspflanze eine Über- und Überstürzung gibt, beispielsweise eine einzigartige Währung, ist es leicht, alle ins Wasser zu ziehen, und die gesamte Strategie kann leicht fehlschlagen. Daher habe ich beim Berechnen des Index einen höchsten und einen niedrigsten Punkt entfernt, so dass der Index fairer ist. Es gibt viele Anzeichen dafür, dass die Währung wieder normal ist und man sie normal kaufen kann. Bitte beachten Sie: Diese Strategie wurde aufgrund von Bedingungen nicht überprüft und ist nur zur Referenz.

Wichtige Inhalte!

  • Ich muss diese Studie lesen.https://www.fmz.com/digest-topic/5294◦ Verständnis für eine Reihe von Fragen wie Strategieprinzipien, Risiken, wie man den Handel durchsucht, wie man die Parameter setzt, wie man die Anteile an der Eröffnung und dem Gesamtkapital anpasst.
  • Der letzte Bericht muss heruntergeladen und in die eigene Umgebung hochgeladen werden. Die tatsächliche Änderung läuft wieder. Wenn Sie diesen Bericht bereits gelesen haben, aktualisieren Sie die Daten der letzten Woche.
  • Strategien können nicht direkt nachgeprüft werden, sie müssen in der Forschung nachgeprüft werden.
  • Die Strategiecode und die Standardparameter sind nur für Forschungszwecke bestimmt.
  • Der Code ist öffentlich zugänglich und kann von selbst geändert werden. Kommentare und Feedback sind herzlich willkommen, wenn Sie Probleme haben.
  • Die Strategie muss im Gesamtlagermodus laufen.Die Strategie unterstützt Binance, wobei der Roboter mit dem Standard-Transaktionspaar und der K-Linien-Zyklus erstellt wird, ohne dass die Strategie die K-Line verwendet.

Die Strategie

Die Währungen, die höher als der Bitcoin-Coin-Price-Index und niedriger als der Bitcoin-Index liegen, werden mit größerer Abweichung größer sein.img

Strategische Logik

1. Aktualisierung des Marktes und der Kontobewahrung, wobei der erste Lauf den ursprünglichen Preis (die neu hinzugefügten Währungen berechnet nach dem Zeitpunkt des Beitritts) erfasst 2. Aktualisieren Sie den Index, der Index ist der Münze-Bitcoin-Preisindex = mean ((sum)) 3. Nach Abweichungsindex-Bewusstsein, nach Abweichungsgröße, nach Positionsgröße 4. Die Bestellung und die Menge der Bestellung werden von Ice Mountain beauftragt und werden nach dem Gegenhandelspreis getätigt (Kauf-Verkauf-Preis).Wenn Sie eine Bestellung anmelden, wird sie sofort widerrufen (so dass Sie viele fehlgeschlagene Bestellungen sehen, normal). 5.再次循环

Strategieparameter

img

  • Trade_symbols: Handelswährungen, die von der Forschungsplattform selbst gefiltert werden müssen, können auch in BTC aufgenommen werden
  • Trade_value: Der Wert der Münze muss anhand des gesamten investierten Kapitals bestimmt werden, um den Umfang des Hebels durch eine Rückprüfung der Umgebung zu bestimmen.
  • Adjust_value: Vertragswert (USDT-Kurs) Anpassung der Abweichung, zu viel Anpassung ist langsamer, kann nicht unter 20 liegen, sonst wird die Mindesttransaktion nicht erreicht
  • Ice_value: Ein Eisberg-Aufgabegrad, ebenfalls nicht kleiner als 20, der kleinere von Adjust_value/Ice_value
  • Reset: Zurücksetzen von historischen Daten

Strategische Risiken

Beachten Sie, dass, wenn eine Währung aus einem unabhängigen Markt tritt, z. B. ein paar Mal höher als der Index, eine große Anzahl von Leerstandspositionen auf der Währung angesammelt wird. Ein ähnlicher starker Rückgang kann dazu führen, dass die Strategie viel zu tun hat.


//向上偏离最大的币的索引
var highIndex=0;
//向下偏离最大的币的索引
var lowIndex=0;

var trade_symbols = Trade_symbols.split(',')
var symbols = trade_symbols
var index = 1 //指数
if(trade_symbols.indexOf('BTC')<0){
    symbols = trade_symbols.concat(['BTC'])
}
var update_profit_time = 0
var assets = {}
var trade_info = {}
var exchange_info = HttpQuery('https://fapi.binance.com/fapi/v1/exchangeInfo')
if(!exchange_info){
    Log('无法连接网络')
    return
}
exchange_info = JSON.parse(exchange_info)
for (var i=0; i<exchange_info.symbols.length; i++){
    if(symbols.indexOf(exchange_info.symbols[i].baseAsset) > -1){
       assets[exchange_info.symbols[i].baseAsset] = {amount:0, hold_price:0, value:0, bid_price:0, ask_price:0, 
                                                     btc_price:0, btc_change:1,btc_diff:0,
                                                     realised_profit:0, margin:0, unrealised_profit:0}
       trade_info[exchange_info.symbols[i].baseAsset] = {minQty:parseFloat(exchange_info.symbols[i].filters[1].minQty),
                                                         priceSize:parseInt((Math.log10(1.1/parseFloat(exchange_info.symbols[i].filters[0].tickSize)))),
                                                         amountSize:parseInt((Math.log10(1.1/parseFloat(exchange_info.symbols[i].filters[1].stepSize))))
                                                        }
    }
}
assets.USDT = {unrealised_profit:0, margin:0, margin_balance:0, total_balance:0, leverage:0, update_time:0}

function updateAccount(){ //更新账户和持仓
    var account = exchange.GetAccount()
    var pos = exchange.GetPosition()
    if (account == null || pos == null ){
        Log('update account time out')
        return
    }
    assets.USDT.update_time = Date.now()
    for(var i=0; i<trade_symbols.length; i++){
        assets[trade_symbols[i]].margin = 0
        assets[trade_symbols[i]].unrealised_profit = 0
        assets[trade_symbols[i]].hold_price = 0
        assets[trade_symbols[i]].amount = 0
        assets[trade_symbols[i]].unrealised_profit = 0
    } 
    for(var j=0; j<account.Info.positions.length; j++){
        var pair = account.Info.positions[j].symbol 
        var coin = pair.slice(0,pair.length-4)
        if(symbols.indexOf(coin) < 0){continue}
        assets[coin].margin = parseFloat(account.Info.positions[j].initialMargin) + parseFloat(account.Info.positions[j].maintMargin)
        assets[coin].unrealised_profit = parseFloat(account.Info.positions[j].unrealizedProfit)
    }
    assets.USDT.margin = _N(parseFloat(account.Info.totalInitialMargin) + parseFloat(account.Info.totalMaintMargin),2)
    assets.USDT.margin_balance = _N(parseFloat(account.Info.totalMarginBalance),2)
    assets.USDT.total_balance = _N(parseFloat(account.Info.totalWalletBalance),2)
    assets.USDT.unrealised_profit = _N(parseFloat(account.Info.totalUnrealizedProfit),2)
    assets.USDT.leverage = _N(assets.USDT.margin/assets.USDT.total_balance,2)
    
    if(pos.length > 0){
        pos = JSON.parse(exchange.GetRawJSON())
        for(var k=0; k<pos.length; k++){
            var pair = pos[k].symbol
            var coin = pair.slice(0,pair.length-4)
            if(symbols.indexOf(coin) < 0){continue}
            assets[coin].hold_price = parseFloat(pos[k].entryPrice)
            assets[coin].amount = parseFloat(pos[k].positionAmt)
            assets[coin].unrealised_profit = parseFloat(pos[k].unRealizedProfit)
        }
    }
}

function updateIndex(){ //更新指数
    var init_prices = {}
    if(!_G('init_prices') || Reset){
        for(var i=0; i<trade_symbols.length; i++){
            init_prices[trade_symbols[i]] = (assets[trade_symbols[i]].ask_price+assets[trade_symbols[i]].bid_price)/(assets.BTC.ask_price+assets.BTC.bid_price)
        }
        Log('保存启动时的价格')
        _G('init_prices',init_prices)
    }else{
        init_prices = _G('init_prices')
        var temp = 0
        
        highIndex=0;
        lowIndex=0;
        var highChange;var lowChange;
        //本次计算找出最大偏离的高低分
        for(var i=0; i<trade_symbols.length; i++){
            assets[trade_symbols[i]].btc_price =  (assets[trade_symbols[i]].ask_price+assets[trade_symbols[i]].bid_price)/(assets.BTC.ask_price+assets.BTC.bid_price)
            if(!init_prices[trade_symbols[i]]){
                Log('添加新的币种',trade_symbols[i])
                init_prices[trade_symbols[i]] = assets[trade_symbols[i]].btc_price 
                _G('init_prices',init_prices)
            }
            assets[trade_symbols[i]].btc_change = _N(assets[trade_symbols[i]].btc_price/init_prices[trade_symbols[i]],4)
            if(i==0){
                highChange=assets[trade_symbols[i]].btc_change;
                lowChange=assets[trade_symbols[i]].btc_change;
            }
            
            if(highChange<assets[trade_symbols[i]].btc_change){
                highChange=assets[trade_symbols[i]].btc_change;
                highIndex=i;
            }
            if(lowChange>assets[trade_symbols[i]].btc_change){
                lowChange=assets[trade_symbols[i]].btc_change;
                lowIndex=i;
            }
        }
        
        for(var i=0; i<trade_symbols.length; i++){
            assets[trade_symbols[i]].btc_price =  (assets[trade_symbols[i]].ask_price+assets[trade_symbols[i]].bid_price)/(assets.BTC.ask_price+assets.BTC.bid_price)
            assets[trade_symbols[i]].btc_change = _N(assets[trade_symbols[i]].btc_price/init_prices[trade_symbols[i]],4)
            if(i!=lowIndex&&i!=highIndex){ //去掉高低分的影响
                temp += assets[trade_symbols[i]].btc_change
            }
        }
        //因为去掉了最高最低分,所以减2
        index = _N(temp/(trade_symbols.length-2), 4)
    }
    
}

function updateTick(){ //更新行情
    var ticker = HttpQuery('https://fapi.binance.com/fapi/v1/ticker/bookTicker')
    try {
        ticker = JSON.parse(ticker)
    }catch(e){
        Log('get ticker time out')
        return
    }
    for(var i=0; i<ticker.length; i++){
        var pair = ticker[i].symbol 
        var coin = pair.slice(0,pair.length-4)
        if(symbols.indexOf(coin) < 0){continue}
        assets[coin].ask_price = parseFloat(ticker[i].askPrice)
        assets[coin].bid_price = parseFloat(ticker[i].bidPrice)
        assets[coin].ask_value = _N(assets[coin].amount*assets[coin].ask_price, 2)
        assets[coin].bid_value = _N(assets[coin].amount*assets[coin].bid_price, 2)
    }
    updateIndex()
    for(var i=0; i<trade_symbols.length; i++){
        assets[trade_symbols[i]].btc_diff = _N(assets[trade_symbols[i]].btc_change - index, 4)
    }
}

function trade(symbol, dirction, value){ //交易
    if(Date.now()-assets.USDT.update_time > 10*1000){
        Log('更新账户延时,不交易')
        return
    }
    var price = dirction == 'sell' ? assets[symbol].bid_price : assets[symbol].ask_price
    var amount = _N(Math.min(value,Ice_value)/price, trade_info[symbol].amountSize)
    if(amount <= trade_info[symbol].minQty){
        Log(symbol, '合约价值偏离或冰山委托订单的大小设置过小,达不到最小成交, 至少需要: ', _N(trade_info[symbol].minQty*price,0))
        return
    }
    exchange.IO("currency", symbol+'_'+'USDT')
    exchange.SetContractType('swap')
    exchange.SetDirection(dirction)
    var f = dirction == 'buy' ? 'Buy' : 'Sell'
    var id = exchange[f](price, amount, symbol)
    if(id){
        exchange.CancelOrder(id) //订单会立即撤销
    }
}

function updateStatus(){ //状态栏信息
        var table = {type: 'table', title: '交易对信息更新', 
             cols: ['Symbol', 'amount', 'hold_price',  'price', 'diff', 'value', 'margin', 'unrealised_profit'],
             rows: []}
        var infoList;
    for (var i=0; i<symbols.length; i++){
        var price = _N((assets[symbols[i]].ask_price + assets[symbols[i]].bid_price)/2, trade_info[symbols[i]].priceSize)
        var value = _N((assets[symbols[i]].ask_value + assets[symbols[i]].bid_value)/2, 2)
        if(i==lowIndex){
           infoList = [symbols[i]+"Low", assets[symbols[i]].amount, assets[symbols[i]].hold_price, price, assets[symbols[i]].btc_diff, value, _N(assets[symbols[i]].margin,3), _N(assets[symbols[i]].unrealised_profit,3)]    
        }else if(i==highIndex){
           infoList = [symbols[i]+"High", assets[symbols[i]].amount, assets[symbols[i]].hold_price, price, assets[symbols[i]].btc_diff, value, _N(assets[symbols[i]].margin,3), _N(assets[symbols[i]].unrealised_profit,3)]
        }else{
           infoList = [symbols[i], assets[symbols[i]].amount, assets[symbols[i]].hold_price, price, assets[symbols[i]].btc_diff, value, _N(assets[symbols[i]].margin,3), _N(assets[symbols[i]].unrealised_profit,3)]
        }
        table.rows.push(infoList)
    }
    var logString = _D() + '   ' + JSON.stringify(assets.USDT) + ' Index:' + index + '\n'
    LogStatus(logString + '`' + JSON.stringify(table) + '`')
    
    if(Date.now()-update_profit_time > Log_profit_interval*1000){
        LogProfit(_N(assets.USDT.margin_balance,3))
        update_profit_time = Date.now()
    }
    
}

function onTick(){ //策略逻辑部分
    for(var i=0; i<trade_symbols.length; i++){
        var symbol = trade_symbols[i]
        if(assets[symbol].ask_price == 0){ continue }
        var aim_value = -Trade_value * _N(assets[symbol].btc_diff/0.01,1)
        
        if(i!=lowIndex&&i!=highIndex){ //高低分的货币不交易
           if(aim_value - assets[symbol].ask_value > Adjust_value&&assets[symbol].ask_value<Max_amount){
              trade(symbol,'buy', aim_value - assets[symbol].ask_value)
           }
           if(aim_value - assets[symbol].bid_value < -Adjust_value&&assets[symbol].bid_value<Max_amount){
              trade(symbol,'sell', -(aim_value - assets[symbol].bid_value))
           }
        }
    }
}

function main() {
    while(true){
        updateAccount()
        updateTick()
        onTick()
        updateStatus()
        Sleep(Interval*1000)
    }
}

Verwandt

Mehr

Die Ausgabe ist abgeschlossen.Wie hoch ist der Leverage-Leverage, und wie viel Geld kann man dafür verwenden?

Quantifizierung der ZonenDer größte Wert einer einzelnen Währung.

Leichte WolkenHallo, ich habe eine Frage. Max_amount Dies ist der maximale Betrag für jede Handelspaare oder die maximale Anzahlung?