Торговые стратегии, основанные на прорывах гистограммы


Дата создания: 2023-11-15 15:25:57 Последнее изменение: 2023-11-15 15:25:57
Копировать: 0 Количество просмотров: 700
1
Подписаться
1617
Подписчики

Торговые стратегии, основанные на прорывах гистограммы

Обзор

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

Стратегический принцип

  1. Вычислите быстрое скользящее среднее ((20 циклов) и медленное скользящее среднее ((50 циклов)

  2. На основе K-линии вычислить, сформировался ли восходящий прямоугольник (close>open) или нисходящий прямоугольник (close

  3. Определить, превзошел ли продольный верхний или нижний предел предыдущей K-линии. Если это восходящий продольный и превзошел верхний предел предыдущей K-линии, то создается многоголовый сигнал; если это нисходящий продольный и превзошел нижний предел предыдущей K-линии, то создается пустой сигнал прорыва.

  4. При этом следует определить, находится ли быстрая скользящая средняя над медленной скользящей средней, и если да, то следует определить ее как многоголовую тенденцию; наоборот, следует определить как холостую тенденцию.

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

  6. При получении эффективного многоголового прорыва открывается многоголовый билет по определенным стандартам остановки и остановки; при получении эффективного пустого прорыва открывается пустой билет по определенным стандартам остановки и остановки.

  7. Если быстрые и медленные скользящие средние пересекаются, то текущая позиция уравняется.

Анализ преимуществ

  • Использование границы прямоугольника в качестве прорывного отверстия означает более сильный сигнал прорыва.

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

  • С учетом тенденций и прорывов, чтобы стратегия работала хорошо в условиях тенденций.

  • Параметры могут быть оптимизированы для различных сортов и временных периодов.

Риски и решения

  • Риск неудачного прорыва. Решение заключается в том, чтобы выбрать более крупный прорыв, чтобы обеспечить более сильный прорыв.

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

  • Риск, что слишком маленькая настройка остановки приводит к слишком частому остановке. Решение состоит в том, чтобы скорректировать степень остановки в зависимости от динамики разных сортов и временных периодов.

  • Риск небольшой прибыли в пространстве. Решение состоит в том, чтобы установить разную прибыльно-неприбыльную долю в зависимости от динамики разных сортов и временных периодов.

Направление оптимизации

  • В целом, параметры движущейся средней линии, параметры прорыва, стоп-магнитуды и прибыльно-неприбыльность должны быть протестированы и оптимизированы в зависимости от разных сортов и временных периодов, чтобы настраивать параметры стратегии.

  • Можно тестировать различные типы скользящих средних (например, EMA, SMA и т. д.) и искать более подходящий средний показатель.

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

  • Динамически оптимизировать параметры можно с помощью методов машинного обучения и др.

  • Можно проводить статистическое обучение по успешности прорыва и корректировать параметры прорыва.

Подвести итог

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

Исходный код стратегии
/*backtest
start: 2023-10-15 00:00:00
end: 2023-11-14 00:00:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4
//Backtested Time Frame: H1
//Default Settings: Are meant to run successfully on all currency pairs to reduce over-fitting.
//Risk Warning: This is a forex trading robot, backtest performance will not equal future performance, USE AT YOUR OWN RISK.
//Code Warning: Although every effort has been made for robustness, this code has not been vetted by independent 3rd parties.
strategy("Pin Bar Strategy v1", overlay=true)

// User Input
usr_risk = input(title="Equity Risk (%)",type=input.integer,minval=1,maxval=100,step=1,defval=3,confirm=false)
atr_mult = input(title="Stop Loss (x*ATR, Float)",type=input.float,minval=0.1,maxval=100,step=0.1,defval=1.9,confirm=false)
trd_rewd = input(title="Risk : Reward (1 : x*SL, Float)",type=input.float,minval=0.1,maxval=100,step=0.1,defval=3.1,confirm=false)
sma_fast = input(title="Fast MA (Period)",type=input.integer,minval=1,maxval=500,step=1,defval=20,confirm=false)
sma_slow = input(title="Slow MA (Period)",type=input.integer,minval=1,maxval=500,step=1,defval=50,confirm=false)
atr_valu = input(title="ATR (Period)",type=input.integer,minval=1,maxval=500,step=1,defval=14,confirm=false)
use_slpe = input(title="Use MA Slope (Boolean)",type=input.bool,defval=true,confirm=false)
slp_long = input(title="Bull Slope Angle (Deg)",type=input.integer,minval=-90,maxval=90,step=1,defval=1,confirm=false)
slp_shrt = input(title="Bear Slope Angle (Deg)",type=input.integer,minval=-90,maxval=90,step=1,defval=-1,confirm=false)
emg_exit = input(title="Exit When MA Re-Cross (Boolean)",type=input.bool,defval=true,confirm=false)
ent_canc = input(title="Cancel Entry After X Bars (Period)",type=input.integer,minval=1,maxval=500,step=1,defval=3,confirm=false)

// Create Indicators
fastSMA = sma(close, sma_fast)
slowSMA = sma(close, sma_slow)
bullishPinBar = ((close > open) and ((open - low) > 0.66 * (high - low))) or ((close < open) and ((close - low) > 0.66 * (high - low)))
bearishPinBar = ((close > open) and ((high - close) > 0.66 * (high - low))) or ((close < open) and ((high - open) > 0.66 * (high - low)))
atr = atr(atr_valu)

// Specify Trend Conditions
smaUpTrend = (fastSMA > slowSMA) and (fastSMA[1] > slowSMA[1]) and (fastSMA[2] > slowSMA[2]) and (fastSMA[3] > slowSMA[3]) and (fastSMA[4] > slowSMA[4])
smaDnTrend = (fastSMA < slowSMA) and (fastSMA[1] < slowSMA[1]) and (fastSMA[2] < slowSMA[2]) and (fastSMA[3] < slowSMA[3]) and (fastSMA[4] < slowSMA[4])
candleUpTrend = (close[5] > fastSMA[5]) and (open[5] > fastSMA[5]) and (close[6] > fastSMA[6]) and (open[6] > fastSMA[6]) and (close[7] > fastSMA[7]) and (open[7] > fastSMA[7]) and (close[8] > fastSMA[8]) and (open[8] > fastSMA[8]) and (close[9] > fastSMA[9]) and (open[9] > fastSMA[9]) and (close[10] > fastSMA[10]) and (open[10] > fastSMA[10])
candleDnTrend = (close[5] < fastSMA[5]) and (open[5] < fastSMA[5]) and (close[6] < fastSMA[6]) and (open[6] < fastSMA[6]) and (close[7] < fastSMA[7]) and (open[7] < fastSMA[7]) and (close[8] < fastSMA[8]) and (open[8] < fastSMA[8]) and (close[9] < fastSMA[9]) and (open[9] < fastSMA[9]) and (close[10] < fastSMA[10]) and (open[10] < fastSMA[10])

// Specify Piercing Conditions
bullPierce = ((low < fastSMA) and (open > fastSMA) and (close > fastSMA)) or ((low < slowSMA) and (open > slowSMA) and (close > slowSMA))
bearPierce = ((high > fastSMA) and (open < fastSMA) and (close < fastSMA)) or ((high > slowSMA) and (open < slowSMA) and (close < slowSMA))

// MA Slope Function
angle(_source) =>
    rad2degree=180/3.14159265359
    ang=rad2degree*atan((_source[0] - _source[1])/atr(atr_valu)) 

// Calculate MA Slope
fastSlope=angle(fastSMA)
slowSlope=angle(slowSMA)
slopingUp = fastSlope > slp_long
slopingDn = fastSlope < slp_shrt
    
// Specify Entry Conditions
longEntry = smaUpTrend and bullishPinBar and bullPierce
shortEntry = smaDnTrend and bearishPinBar and bearPierce
longEntryWithSlope = smaUpTrend and bullishPinBar and bullPierce and slopingUp
shortEntryWithSlope = smaDnTrend and bearishPinBar and bearPierce and slopingDn

// Specify Secondary Exit Conditions
longExit = crossunder(fastSMA, slowSMA)
shortExit = crossover(fastSMA, slowSMA)

// Long Entry Function
enterlong() =>
    risk = usr_risk * 0.01 * strategy.equity
    stopLoss = low[1] - atr[1] * atr_mult
    entryPrice = high[1]
    units = risk / (entryPrice - stopLoss)
    takeProfit = entryPrice + trd_rewd * (entryPrice - stopLoss)
    strategy.entry("long", strategy.long, units, stop=entryPrice)
    strategy.exit("exit long", "long", stop=stopLoss, limit=takeProfit)
    
// Short Entry Function
entershort() =>
    risk = usr_risk * 0.01 * strategy.equity
    stopLoss = high[1] + atr[1] * atr_mult
    entryPrice = low[1]
    units = risk / (stopLoss - entryPrice)
    takeProfit = entryPrice - trd_rewd * (stopLoss - entryPrice)
    strategy.entry("short", strategy.short, units, stop=entryPrice)
    strategy.exit("exit short", "short", stop=stopLoss, limit=takeProfit)
    
// Execute Long Entry w/o Slope
if (longEntry and use_slpe == false)
    enterlong()
    
// Execute Long Entry w/ Slope
if (longEntryWithSlope and use_slpe == true)
    enterlong()

// Exit Long Due to Re-Cross
if(longExit and strategy.position_size > 0 and emg_exit)    
    strategy.order("exit long, re-cross", strategy.short, abs(strategy.position_size))

// Cancel the Long Entry
strategy.cancel("long", barssince(longEntry) > ent_canc)

// Execute Short Entry w/o Slope
if (shortEntry and use_slpe == false)
    entershort() 
    
// Execute Short Entry w/ Slope
if (shortEntryWithSlope and use_slpe == true)
    entershort() 

// Exit Short Due to Re-Cross
if(shortExit and strategy.position_size < 0 and emg_exit)    
    strategy.order("exit short, re-cross", strategy.long, abs(strategy.position_size))

// Cancel the Short Entry
strategy.cancel("short", barssince(shortEntry) > ent_canc)

// Plot Moving Averages to Chart
plot(fastSMA, color=color.red)
plot(slowSMA, color=color.blue)

// Plot Pin Bars to Chart
plotshape(bullishPinBar, style=shape.arrowup, location=location.abovebar, color=#FF0000, text='')
plotshape(bearishPinBar, style=shape.arrowdown, location=location.belowbar, color=#0000FF, text='')