विनय रणनीति 2 उच्च और निम्न स्कोर को हटा देता है

लेखक:वर्गों का परिमाण, दिनांकः 2020-04-09 21:44:22
टैगःबाइनेंस

एफएमजेड की सार्वजनिक रणनीति के लिए धन्यवाद, गार्ड के समर्थन के लिए धन्यवाद! उन्होंने खुद दो बदलाव किए हैंः 1, क्योंकि कई दोस्त डिफ़ॉल्ट रूप से 10 गुना 20 गुना लेवलिंग करते हैं, और यह रणनीति पूर्ण स्थिति मोड के लिए है, एक सिक्का उछाल की स्थिति, तो नष्ट हो जाएगा । इसलिए एक Max_amount जोड़ें, एक एकल मुद्रा खरीद राशि इस संख्या से अधिक नहीं होगी, जिससे उछाल की स्थिति को रोका जा सके। 2. यदि सिक्के के पूल में अति-अति-अति-बढ़ती, विशेष रूप से अद्वितीय सिक्के हैं, तो यह सभी को नीचे खींचने के लिए आसान है, और समग्र रणनीति विफल हो सकती है। इसलिए मैंने सूचकांक की गणना करते समय एक उच्चतम स्कोर को हटा दिया, एक निम्नतम स्कोर को हटा दिया, और सूचकांक अधिक निष्पक्ष है। इस तरह के मामलों में विशेष रूप से अनन्य मुद्राओं को सामान्य रूप से बहाल किया जा सकता है, या सामान्य रूप से खरीदा जा सकता है। ध्यान देंः शर्तों के कारण, यह नीति केवल संदर्भ के लिए है और किसी भी नुकसान के लिए जिम्मेदार नहीं है!

महत्वपूर्ण सामग्री!

  • इस अध्ययन को जरूर देखें।https://www.fmz.com/digest-topic/5294♦ रणनीतिक सिद्धांतों, जोखिमों, ट्रेडिंग के लिए कैसे छानें, पैरामीटर कैसे सेट करें, शुरुआती स्थिति और कुल पूंजी का अनुपात आदि के बारे में जानें।
  • पिछले शोध रिपोर्ट को डाउनलोड करने और अपने स्वयं के शोध वातावरण में अपलोड करने की आवश्यकता है। वास्तविक संशोधन फिर से चल रहा है। यदि आपने इस रिपोर्ट को देखा है, तो हाल ही में नवीनतम सप्ताह के आंकड़ों को अपडेट किया गया है।
  • रणनीति को सीधे रीटेस्ट नहीं किया जा सकता है, इसे रिसर्च में रीटेस्ट किया जाना चाहिए।
  • नीति कोड और डिफ़ॉल्ट पैरामीटर केवल अनुसंधान के लिए हैं, और वास्तविक ड्राइव को सावधानीपूर्वक और अपने जोखिम पर चलाने की आवश्यकता है।
  • कोड खुला है, आप इसे स्वयं बदल सकते हैं, यदि कोई समस्या है, तो टिप्पणियों और प्रतिक्रियाओं का स्वागत है, बेहतर है कि आप आविष्कारकों के लिए Binance समुदाय में शामिल हों (शोध रिपोर्ट में शामिल होने का तरीका है)
  • यह रणनीति पूरी तरह से स्टॉक मोड में चलनी चाहिए।रणनीति बिनान का समर्थन करती है, रोबोट बनाने के लिए डिफ़ॉल्ट रूप से लेन-देन जोड़े और K लाइन चक्र का उपयोग करना आवश्यक है, रणनीति K लाइन का उपयोग नहीं करती है।

रणनीतिक सिद्धांत

सिक्के जो सिक्का-बिटकॉइन मूल्य सूचकांक से ऊपर की कीमत पर हैं, वे सिक्के जो सूचकांक से नीचे हैं, वे जितने अधिक विचलन करते हैं, उतने ही बड़े पद होते हैं।img

रणनीतिक तर्क

1. बाजार और खाता रखरखाव को अपडेट करें, पहली बार चलाने के लिए प्रारंभिक मूल्य दर्ज करें ((नई जोड़ी गई मुद्राओं को शामिल होने के समय के अनुसार गणना की जाती है) 2. सूचकांक अद्यतन करें, सूचकांक सिक्का-बिटकॉइन मूल्य सूचकांक = mean ((sum)) सिक्का मूल्य / बिटकॉइन मूल्य) / ((सिक्का प्रारंभिक मूल्य / बिटकॉइन प्रारंभिक मूल्य)) है 3. विचलन सूचकांक के आधार पर अधिक खाली करना, विचलन के आकार के आधार पर स्थिति का निर्धारण करना 4. आदेश, आदेश की मात्रा आइस पर्वत द्वारा सौंपे जाने पर तय की जाती है, जो कि एक ही कीमत पर खरीदी जाती है।एक बार जब आप अपना ऑर्डर जमा करते हैं, तो तुरंत रद्द कर दिया जाता है (इसलिए आप बहुत सारे रद्द किए गए असफल ऑर्डर देखेंगे, सामान्य) 5.再次循环

रणनीति पैरामीटर

img

  • Trade_symbols: ट्रेड की जाने वाली करेंसी, जिसे आपको अपने शोध प्लेटफॉर्म के आधार पर स्वयं को छानने की आवश्यकता है, BTC में शामिल हो सकती है
  • Trade_value: नकली सिक्कों के पास मूल्य है, जो आपके द्वारा निवेश किए गए कुल पूंजी के आधार पर निर्णय लेने की आवश्यकता है, जो कि अध्ययन के संदर्भ में पुनर्मूल्यांकन के माध्यम से लीवरेज का आकार देख सकता है
  • Adjust_value: कॉन्ट्रैक्ट वैल्यू (USDT मूल्य निर्धारण) समायोजन विचलन, बहुत अधिक समायोजन धीमा है, 20 से कम नहीं हो सकता है, अन्यथा न्यूनतम लेनदेन तक नहीं पहुंच सकता है
  • Ice_value: हिमशैल को सौंपा गया मान, जो 20 से कम नहीं हो सकता है, जो कि Adjust_value/Ice_value में से छोटा है
  • Reset: इतिहास को पुनर्स्थापित करें

रणनीतिक जोखिम

ध्यान दें कि यदि कोई मुद्रा स्वतंत्र बाजार से बाहर निकलती है, जैसे कि सूचकांक के सापेक्ष कई गुना बढ़ना, तो उस मुद्रा पर बड़ी संख्या में खाली स्थान जमा हो जाएगा, और एक ही भारी गिरावट से रणनीतिक रूप से बहुत अधिक किया जा सकता है।


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

संबंधित

अधिक

qq813380629आम तौर पर, यह कितना लाभ उठाता है और कितना पैसा खर्च करता है?

वर्गों का परिमाणएक मुद्रा के लिए सबसे बड़ा मूल्य है

हल्के बादलनमस्ते, एक सवाल है। Max_amount यह प्रत्येक ट्रेडिंग जोड़ी के लिए अधिकतम रखरखाव मूल्य या अधिकतम गारंटी राशि है? धन्यवाद.