Strategi Binance 2: Menghilangkan Nilai Tinggi dan Rendah

Penulis:Kualifikasi kelas, Tanggal: 2020-04-09 21:44:22
Tag:Binance

Terima kasih atas kebijakan terbuka FMZ, terima kasih atas dukungan Garda! Dia sendiri membuat dua perubahan: 1, karena banyak teman secara default adalah 10 kali 20 kali leverage, dan strategi ini adalah mode posisi penuh, satu posisi biner, akan dihancurkan. Jadi menambahkan Max_amount, jumlah pembelian mata uang tunggal tidak akan melebihi angka ini, mencegah posisi biner. 2. jika ada koin yang sangat tinggi dan sangat rendah dalam kolam uang, misalnya koin yang unik, mudah untuk menarik semua orang ke bawah, dan strategi keseluruhan mudah gagal. Oleh karena itu, ketika saya menghitung indeks, saya menghilangkan nilai tertinggi, menghilangkan nilai terendah, dan hasil indeks lebih adil. Pada saat itu, para pedagang akan mulai membeli dan menjual barang-barang yang dijual di pasar lokal. Catatan: Karena keterbatasan kondisi, kebijakan ini tidak diuji ulang, hanya untuk referensi, dan tidak bertanggung jawab jika ada kerugian!

Artikel penting!

  • Anda harus melihat penelitian ini.https://www.fmz.com/digest-topic/5294◦ Mengetahui berbagai hal seperti prinsip-prinsip strategi, risiko, cara menyaring perdagangan, cara mengatur parameter, rasio posisi awal dan total modal, dan lain sebagainya.
  • Laporan penelitian sebelumnya harus diunduh dan diunggah ke lingkungan penelitian Anda sendiri. Modifikasi sebenarnya berjalan lagi. Jika Anda telah membaca laporan ini, Anda baru saja memperbarui data minggu terbaru.
  • Strategi tidak dapat diuji secara langsung, tetapi harus diuji dalam lingkungan penelitian.
  • Kode strategi dan parameter default hanya untuk penelitian, dan operasi real-time membutuhkan kewaspadaan dan risiko.
  • Kode adalah terbuka, dapat dimodifikasi sendiri, jika ada masalah, silakan komentar dan umpan balik, sebaiknya bergabung dengan komunitas Penemu Binance (dalam laporan penelitian ada cara untuk bergabung)
  • Strategi ini harus berjalan dalam mode seluruh gudang.Strategi ini mendukung Binance, membuat robot dengan pasangan transaksi default dan siklus garis K, strategi ini tidak menggunakan garis K.

Prinsip Strategi

Akan membuat koin dengan harga kosong lebih tinggi dari indeks harga Bitcoin-Coincoin, lebih rendah dari indeks, semakin besar deviasi, semakin besar posisi.img

Logika strategis

1. memperbarui pasar dan menyimpan akun, pertama kali berjalan akan mencatat harga awal (mata uang baru yang ditambahkan dihitung sesuai dengan waktu yang ditambahkan) 2. Update indeks, indeksnya adalah indeks harga koin-bitcoin = mean(sum((harga koin-bitcoin/harga bitcoin)/ ((harga awal koin-bitcoin/harga awal bitcoin)) 3. Menentukan posisi sesuai dengan ukuran deviasi. 4. Memesan, jumlah pesanan berikutnya ditentukan oleh Ice Mountain, sesuai dengan harga transaksi (membeli dengan menjual satu harga).Jika Anda tidak memiliki akun Facebook, maka Anda tidak akan dapat mengakses akun Instagram Anda, dan Anda tidak akan dapat mengaksesnya. 5.再次循环

Parameter Strategi

img

  • Trade_symbols: Mata uang yang diperdagangkan, yang harus disaring sendiri berdasarkan platform penelitian, juga dapat bergabung dengan BTC
  • Trade_value: Bitcoin tidak memiliki nilai, harus diputuskan berdasarkan total modal yang diinvestasikan sendiri, dan ukuran leverage dapat dilihat melalui uji ulang lingkungan penelitian
  • Adjust_value: Nilai kontrak (USDT) nilai penyesuaian deviasi, penyesuaian yang terlalu besar lebih lambat, tidak dapat di bawah 20, atau tidak akan mencapai transaksi minimum
  • Ice_value: Nilai yang diutus gunung es, juga tidak bisa kurang dari 20, pilih yang lebih kecil dari Adjust_value/Ice_value
  • Reset: Mengubah data historis

Risiko Strategis

Perhatikan bahwa jika suatu mata uang keluar dari pasar independen, misalnya naik beberapa kali dibandingkan indeks, maka akan menumpuk banyak posisi kosong pada mata uang tersebut, dan penurunan yang sama juga akan membuat strategi banyak dilakukan.


//向上偏离最大的币的索引
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)
    }
}

Berkaitan

Lebih banyak

qq813380629Bagaimana dengan leverage yang digunakan?

Kualifikasi kelasadalah nilai terbesar dari satu mata uang

Awan ringanHalo, ada pertanyaan? Max_amount Ini adalah nilai maksimum dari setiap pasangan perdagangan atau jumlah jaminan maksimum? Terima kasih.