Биньань устойчивая многовалютная стратегия хеджирования Оригинальная версия ((делать много сверхпадений делать пустого сверхпульса) 13 апреля обновленный модуль остановки убытков

Автор:Трава, Дата: 2020-04-04 21:24:43
Тэги:Binance

Эта политика уже доступна в обновленном варианте платы, а также в WeChat wangweibing_ustb, чтобы узнать больше.

Важная информация!

  • Это исследование стоит посмотреть.https://www.fmz.com/digest-topic/5294Ознакомьтесь с целым рядом вопросов, таких как принципы стратегии, риски, способы отбора сделок, параметры, соотношение открытых позиций и общего капитала.
  • Предыдущий отчет необходимо скачать и загрузить в собственную исследовательскую среду. Фактические изменения выполняются снова. Если вы уже читали этот отчет и недавно обновили данные за последнюю неделю.
  • Если робот задерживается надолго, он должен перезагрузить данные или построить новый.
  • Стратегия не может быть ретестована напрямую, она должна быть ретестована в исследовательской среде.
  • Политика кода и параметры по умолчанию предназначены только для исследования, и для работы на дискета требуется осторожность, чтобы решить параметры в соответствии с собственными исследованиями.Риск на себя
  • Стратегия не может быть прибыльной каждый день, если посмотреть на историю, 1-2-недельные сдвиги и отступления - это нормально, и нужно правильно относиться.
  • Код является открытым, его можно изменить самостоятельно, если есть какие-либо проблемы, добро пожаловать на комментарии и отзывы, лучше присоединиться к группе разработчиков Binance (в докладе есть способ присоединения), чтобы получить уведомления об обновлениях.
  • Стратегия поддерживает только валютные фьючерсы, требует работы в режиме полного хранения, не настраивайте двунаправленное хранение!!, при создании робота можно использовать пары по умолчанию и циклы K-линии, стратегия не использует K-линию.
  • Тактика и другие тактики, а также ручные действия конфликтуют, и необходимо обратить внимание на это.
  • Для работы на реальном диске требуется зарубежный хост, на тестовом этапе можно арендовать сервер Ali Cloud Hong Kong на платформе одним щелчком мыши, чтобы аренда была дешевле в месяц ((просто минимальная конфигурация, развертывание учебника:https://www.fmz.com/bbs-topic/2848)
  • Фьючерсы и наличные должны быть добавлены отдельно.Futures_Binance
  • Эта стратегия перезагрузки не повлияет, но новые роботы будут перезаписывать исторические данные.
  • Политика может быть обновлена в зависимости от отзывов пользователей, прямо Ctrl + A копировать код, покрывать сохранить (обычно не обновлять параметры), перезагрузить бот, чтобы использовать последний код.
  • Стратегия начинается без торговли, первая запуск требует записи данных, нужно ждать изменения рынка, прежде чем торговать.

Обновление 4.16

Изменили ошибку, которая останавливала повреждение

Изменение параметров по умолчанию:

var Alpha = 0.001 //指数移动平均的Alpha参数,设置的越大,基准价格跟踪越敏感,最终持仓也会越低,降低了杠杆,但会降低收益,具体需要根据回测结果自己权衡
var Update_base_price_time_interval = 60 //多久更新一次基准价格, 单位秒,和Alpha参数相关,Alpha 设置的越小,这个间隔也可以设置的更小

4.13 Обновления

Стойкость Stop_loss 0.8 означает, что когда средства достигают 80% от начального капитала, Stop_loss, освобождение всех позиций, прекращение стратегии. По мере выполнения стратегии, Stop_loss может быть установлен больше чем 1 ((возобновление действия), например, от 1000 до 1500, Stop_loss на 1.3 и возвращение до 1300 юаней Stop_loss. Не хотелось бы, чтобы этот параметр был настроен очень мало. Риск очень мал.

Max_diff и Min_diff ограничивают степень отклонения, которую необходимо определить самостоятельно в зависимости от собственной trade_value, общего капитала и способности к риску.

Для простого примера, если торгуется 20 монет, одна из них постепенно повышается до отклонения 0.4 и перестает торговаться, а остальные остаются неизменными, теряя 7 раз trade_value.

var Stop_loss = 0.8 
var Max_diff = 0.4 //当偏差diff大于0.4时,不继续加空仓, 自行设置
var Min_diff = -0.3 //当diff小于-0.3时,不继续加多仓, 自行设置

4.10 Обновления

Код политики копируется в локальную политику, прямиком перекрывается сохраняется, рестартируется, но сохраняет свое местоположение.

Например, в Китае существуют более 10 000 фьючерсов на биткойн, которые продаются в разных странах мира.https://www.fmz.com/bbs-topic/5364

Оригинальная стратегия индекса котировок = mean ((sum)) (((цены котировок/цены биткойнов) / ((начальная цена котировок/начальная цена биткойнов))). Самая большая проблема заключается в сопоставлении новейшей цены и начальной цены на старте стратегии, которая с течением времени растет и становится все более отклонённой, одна валюта может держать много позиций, высокий риск, и в конечном итоге будет держать много позиций, увеличивая риск и отказ.

Последний индекс котировок = mean ((sum (((((котировок/котировок биткоина) /EMA ((котировок/котировок биткоина))), т.е. сравнивается с ценой на удобной линии, может отслеживать последние изменения цены, более гибкий, ретроспективный и обнаруженный снижает стратегию удержания, а также уменьшает отзыв.

Для беспроблемного обновления два из параметров написаны в первые две строки стратегического кода, которые изменяются по мере необходимости.

Альфа = 0.04 параметр движущегося индекса, чем больше установлено, тем более чувствительны отслеживание базовой цены, чем меньше сделок, тем меньше будет и окончательное держание, снижая рычаг, но снижая прибыль, снижая максимальное отклонение, можно увеличить объем сделок, которые необходимо взвесить в соответствии с результатами обратной проверки. Update_base_price_time_interval = 30*60 Чем дольше обновляется один раз базовая цена, единицы секунды, и связанные с параметрами Alpha, чем меньше установлен альфа, тем меньше этот интервал может быть установлен

Если вы читаете эту статью и хотите торговать всеми валютами, вот список.ETH,BCH,XRP,EOS,LTC,TRX,ETC,LINK,XLM,ADA,XMR,DASH,ZEC,XTZ,BNB,ATOM,ONT,IOTA,BAT,VET,NEO,QTUM,IOST

Присоединяйтесь к группе Weibo, чтобы получить обновления о битве на Биткойн

Если вы не хотите, чтобы ваши сообщения были переведены на другие языки, вы можете использовать эти сообщения для обмена информацией.

https://www.fmz.comimg

Принципы стратегии

Снижение курса валют выше копейки-биткоина, снижение курса валют ниже индекса, чем больше отклонение, тем больше позиции.img

Стратегическая логика

1. обновление рынка и счета хранения, первый раз запуск записывает начальную цену ((новые добавленные валюты рассчитываются в соответствии с временем добавления) 2. Обновление индекса, индекс - это индекс копейки - цена биткоина = mean(sum((цены копейки/цена биткоина)/(начальная цена копейки/начальная цена биткоина))) 3. Определение большего количества вакансий по индексу отклонения, определение позиций по размеру отклонения 4. Заказ, количество заказов определяется по поручению Айсхамы, в соответствии с контрактной ценой сделки ("купить и продать по цене").После подачи заказа немедленно аннулировать (так что вы увидите много неудачных аннулирований заказа 400: {code:-2011,msg:Unknown order sent.}, нормальное явление) 5.再次循环

Леверидж в пакете состояния означает, что гарантия уже использована, и она должна оставаться на низком уровне, чтобы удовлетворить новые открытые позиции.

Параметры стратегии

img

  • Trade_symbols: валюты, которые торгуются, требуют самостоятельной фильтрации на основе исследовательской платформы, также могут быть включены в BTC
  • Trade_value: цена копейки (BTC) имеет значение 1% для каждого отклонения в индексе, которое необходимо решить в зависимости от своего общего капитала и рисковых предпочтений. Рекомендуется установить на 3-10% от общего капитала.
  • Adjust_value: изменение отклонения в стоимости контракта (USDT). Когда индекс отклоняется от * Trade_value - текущее состояние > Adjust_value, то есть разница между целевым состоянием и текущим состоянием превышает это значение, начинается торговля. Слишком большие изменения медленны, слишком малые сделки часто, не могут быть ниже 10, иначе не достигнут минимальной сделки, рекомендуется установить на 40% от Trade_value.
  • Ice_value: значение поручения айсберга, также не может быть ниже 10, фактически выберите Adjust_value меньшее из Ice_value, если больше средств можно установить относительно большие некоторые такие изменения быстрее, рекомендуется не менее 20% от Adjust_value, так что 5 раз айсберга может завершить сделку, конечно, когда Trade_value не большой, Ice_value может быть установлен относительно большим, один или два раза можно настроить.
  • Interval: циклическое время покоя, которое может быть настроено на меньшее, например, 1s, но не может превышать пределы частоты биан.
  • Reset: перезагрузить исторические данные, чтобы восстановить начальную цену ссылки на политику на текущую цену, обычно без необходимости настройки

Стратегические риски

Обратите внимание, что если валюта выходит из независимого рынка, например, выросла в несколько раз по отношению к индексу, то будет накапливаться большое количество свободных позиций на этой валюте, и то же самое значительное падение также позволит сделать стратегию больше.




var Alpha = 0.001 //指数移动平均的Alpha参数,设置的越大,基准价格跟踪越敏感,最终持仓也会越低,降低了杠杆,但会降低收益,具体需要根据回测结果自己权衡
var Update_base_price_time_interval = 60 //多久更新一次基准价格, 单位秒,和Alpha参数相关,Alpha 设置的越小,这个间隔也可以设置的更小

//Stop_loss设置为0.8表示当资金达到低于初始资金的80%时,止损,清空所有仓位,停止策略。
//随着策略运行,Stop_loss可以设置大于1(重启生效),比如从1000赚到1500,Stop_loss设置为1.3,则回撤到1300元止损。不想止损可以把这个参数设置的很小。
//风险是大家都用这种止损会形成踩踏,加大亏损。
//初始资金在状态栏的init_balance字段,注意提现等操作会影响,别不小心止损了。
//如果还是怕黑天鹅事件,比如某个币归0等,可以手动提现出来。

var Stop_loss = 0.8 
var Max_diff = 0.4 //当偏差diff大于0.4时,不继续加空仓, 自行设置
var Min_diff = -0.3 //当diff小于-0.3时,不继续加多仓, 自行设置

if(IsVirtual()){
    throw '不能回测,回测参考 https://www.fmz.com/digest-topic/5294 '
}
if(exchange.GetName() != 'Futures_Binance'){
    throw '只支持币安期货交易所,和现货交易所不同,需要单独添加,名称为Futures_Binance'
}
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 update_base_price_time= Date.now()
var assets = {}
var init_prices = {}


var trade_info = {}
var exchange_info = HttpQuery('https://fapi.binance.com/fapi/v1/exchangeInfo')
if(!exchange_info){
    throw '无法连接币安网络,需要海外托管者'
}
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, init_balance:0, stop_balance:0, short_value:0, long_value:0, profit:0}

function updateAccount(){ //更新账户和持仓
    exchange.SetContractType('swap')
    var account = exchange.GetAccount()
    var pos = exchange.GetPosition()
    if (!account || !pos){
        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
    } 
    for(var j=0; j<account.Info.positions.length; j++){
        if(account.Info.positions[j].positionSide == 'BOTH'){
            var pair = account.Info.positions[j].symbol 
            var coin = pair.slice(0,pair.length-4)
            if(trade_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)
    if(assets.USDT.init_balance == 0){
        if(_G('init_balance')){
            assets.USDT.init_balance = _N(_G('init_balance'),2)
        }else{
            assets.USDT.init_balance = assets.USDT.total_balance 
            _G('init_balance',assets.USDT.init_balance)
        }
    }
    assets.USDT.profit = _N(assets.USDT.margin_balance - assets.USDT.init_balance, 2)
    assets.USDT.stop_balance = _N(Stop_loss*assets.USDT.init_balance, 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)
    pos = JSON.parse(exchange.GetRawJSON())
    if(pos.length > 0){
        for(var k=0; k<pos.length; k++){
            var pair = pos[k].symbol
            var coin = pair.slice(0,pair.length-4)
            if(trade_symbols.indexOf(coin) < 0){continue}
            if(pos[k].positionSide != 'BOTH'){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(){ //更新指数
    
    if(!_G('init_prices') || Reset){
        Reset = false
        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')
        if(Date.now() - update_base_price_time > Update_base_price_time_interval*1000){
            update_base_price_time = Date.now()
            for(var i=0; i<trade_symbols.length; i++){ //更新初始价格
                init_prices[trade_symbols[i]] = init_prices[trade_symbols[i]]*(1-Alpha)+Alpha*(assets[trade_symbols[i]].ask_price+assets[trade_symbols[i]].bid_price)/(assets.BTC.ask_price+assets.BTC.bid_price)
            }
            _G('init_prices',init_prices)
        }
        var temp = 0
        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(!(trade_symbols[i] in init_prices)){
                Log('添加新的币种',trade_symbols[i])
                init_prices[trade_symbols[i]] = assets[trade_symbols[i]].btc_price / index
                _G('init_prices',init_prices)
            }
            assets[trade_symbols[i]].btc_change = _N(assets[trade_symbols[i]].btc_price/init_prices[trade_symbols[i]],4)
            temp += assets[trade_symbols[i]].btc_change
        }
        index = _N(temp/trade_symbols.length, 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
    }
    assets.USDT.short_value = 0
    assets.USDT.long_value = 0
    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)
        if(trade_symbols.indexOf(coin) < 0){continue}
        if(assets[coin].amount<0){
            assets.USDT.short_value += Math.abs((assets[coin].ask_value+assets[coin].bid_value)/2)
        }else{
            assets.USDT.long_value += Math.abs((assets[coin].ask_value+assets[coin].bid_value)/2)
        }
        assets.USDT.short_value = _N(assets.USDT.short_value,0)
        assets.USDT.long_value = _N(assets.USDT.long_value,0)
    }
    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)+1)
        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) //订单会立即撤销
    }
    return id
}



function updateStatus(){ //状态栏信息
        var table = {type: 'table', title: '交易对信息', 
             cols: ['币种', '数量', '持仓价格',  '当前价格', '偏离平均', '持仓价值', '保证金', '未实现盈亏'],
             rows: []}
    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)
        var 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 stopLoss(){ //止损函数
    while(true){
        if(assets.USDT.margin_balance < Stop_loss*assets.USDT.init_balance && assets.USDT.init_balance > 0){
            Log('触发止损,当前资金:', assets.USDT.margin_balance, '初始资金:', assets.USDT.init_balance)
            Ice_value = 200 //止损的快一些,可修改
            updateAccount()
            updateTick()
            var trading = false //是否正在交易
            for(var i=0; i<trade_symbols.length; i++){
                var symbol = trade_symbols[i]
                if(assets[symbol].ask_price == 0){ continue }
                if(assets[symbol].bid_value >= trade_info[symbol].minQty*assets[symbol].bid_price){
                    trade(symbol, 'sell', assets[symbol].bid_value)
                    trading = true
                }
                if(assets[symbol].ask_value <= -trade_info[symbol].minQty*assets[symbol].ask_price){
                    trade(symbol, 'buy', -assets[symbol].ask_value)
                    trading = true
                }
            }
            Sleep(1000)
            if(!trading){
                throw '止损结束,如果需要重新运行策略,需要调低止损'
            }
        }else{ //不用止损
            return
        }
    }    
}

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,3)
        if(aim_value - assets[symbol].ask_value >= Adjust_value && assets[symbol].btc_diff > Min_diff && assets.USDT.long_value-assets.USDT.short_value <= 1.1*Trade_value){
            trade(symbol,'buy', aim_value - assets[symbol].ask_value)
        }
        if(aim_value - assets[symbol].bid_value <= -Adjust_value && assets[symbol].btc_diff < Max_diff && assets.USDT.short_value-assets.USDT.long_value <= 1.1*Trade_value){
            trade(symbol,'sell', -(aim_value - assets[symbol].bid_value))
        }
    }
}

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

Связанные

Больше

тиагомбальса@tmbs95 Добавьте меня на телеграмму, заинтересован.

И невесты тоже.Прошу проинформировать, что в функции onTick (()) есть такая строка, assets.USDT.long_value-assets.USDT.short_value <= 1.1*Trade_value, я понимаю, что это было сделано, чтобы предотвратить слишком большие дисбалансы. Однако, это ограничение может серьезно повлиять на скорость открытия позиции.

Майкл.Мы не можем найти это в WeChat?

Кредитная сетьMax_diff и Min_diff не должны быть 0.04 и -0.03?

ВВС никогда не будут рабами.Дайте этому замкнутому кругу немного солнечного света.

Трава/upload/asset/1b39347a88aa4cff916.jpg

Количественное распределение районовЛичность предлагает сделать больше сверхпадений, чтобы сделать более пустых сверхпадений в стратегии ликвидации BNB, эта сделка, которую BNB хочет привлечь к популярности, предполагает, что она будет сверхпадением; нельзя смотреть на это с исторической точки зрения.

И невесты тоже.Это две вещи.

И невесты тоже.Если валюта выходит из независимого рынка, то эта многопространственная балансовая настройка может предотвратить большие потери, поэтому решение не может быть взвешенным.

ТраваВы ошиблись, wangweibing_ustb

ИжансанНа самом деле, если посмотреть на код, результаты обратной проверки всей монеты уже известны, и вам не нужно беспокоиться. При входе, Alpha = 0.05, добавляем LINK, ETC, BNB, первоначальный ретрок истории составляет 3%, максимальный ретрок экстремального рынка не превышает 25%, Trade_Value использует 3% безопасный избыточный ретрок.