Три экспоненциальные скользящие средние и стохастический индекс относительной силы

Автор:Чао Чжан, Дата: 2024-01-30 16:52:48
Тэги:

img

Обзор

Это стратегия, которая сочетает в себе тройную экспоненциальную скользящую среднюю (EMA) и Stochastic Relative Strength Index (Stoch RSI), чтобы генерировать торговые сигналы. Она длинна, когда быстрая EMA пересекает среднюю EMA, а средняя EMA пересекает медленную EMA. Она коротка, когда происходит обратное. Стратегия также использует Stoch RSI в качестве вспомогательного индикатора.

Принципы

  1. Используйте 8, 14, 50-дневные EMA. Продолжайте, когда 8-дневная EMA > 14-дневная EMA > 50-дневная EMA. Продолжайте, когда это обратное.

  2. Используйте стохастический RSI в качестве вспомогательного индикатора. Сначала вычислите 14-дневный RSI, затем вычислите стохастический RSI, наконец, вычислите 3-дневную SMA как линию K и 3-дневную SMA на линии K как линию D. Пересечение K над D дает длинный сигнал.

  3. Ввести длинные сделки при закрытии > 8-дневная EMA на длинном сигнале. Ввести короткие сделки при закрытии < 8-дневная EMA на коротком сигнале.

  4. Стоп-лосс устанавливается на расстоянии 1 ATR ниже/выше входной цены. Прибыль устанавливается на расстоянии 4 ATR выше/ниже входной цены.

Сильные стороны

  1. EMA как базовый показатель может эффективно отслеживать тенденции.

  2. Добавление Stoch RSI может отфильтровать ложные сигналы и повысить точность ввода.

  3. Стоп-лосс и прибыль на основе ATR могут динамически отслеживать волатильность рынка, избегая неправильного размещения.

  4. Эта стратегия имеет хорошо настроенные параметры и отлично работает в периоды тренда.

Риски

  1. Сочетание нескольких индикаторов увеличивает риск. Конфликтные сигналы между EMA и Stoch RSI могут привести к выходу на плохие уровни. В таких случаях сама тенденция цен требует мониторинга.

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

  3. Установка тройной EMA имеет определенное отставание при обратном движении быстрых и средних линий.

  4. Эта стратегия благоприятствует трендовому рынку. Побочные рынки не будут работать хорошо.

Усовершенствования

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

  2. Оптимизация параметров длинного / короткого тестирования на ATR. Например, корректировка стоп-лосса с 1 ATR до 1,5 ATR, получение прибыли с 4 ATR до 3 ATR для достижения лучших результатов.

  3. Удаление Stoch RSI и сохранение только MAs для фильтрации шума и более стабильной прибыли.

  4. Добавление дополнительных критериев для оценки тенденции, таких как объемы торговли, для работы ниже значительных уровней.

Заключение

Эта стратегия сочетает в себе тройную EMA и Stoch RSI для определения тенденций. Строгие сигналы входа уменьшают ненужные сделки. Динамический SL и TP на основе ATR делают параметры адаптивными.


/*backtest
start: 2023-12-01 00:00:00
end: 2023-12-31 23:59:59
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//              3ESRA
//              v0.2a

// Coded by Vaida Bogdan

// 3ESRA consists of a 3 EMA cross + a close above (for longs) the quickest EMA
// or below (for shorts). Note that I've deactivated the RSI Cross Over/Under
// (you can modify the code and activate it). The strategy also uses a stop loss
// that's at 1 ATR distance from the entry price and a take profit that's at
// 4 times the ATR distance from the entry price.

// Feedback:
// Tested BTCUSDT Daily
// 1. Stoch-RSI makes you miss opportunities.
// 2. Changing RR to 4:1 times ATR works better.

//@version=4
strategy(title="3 EMA + Stochastic RSI + ATR", shorttitle="3ESRA", overlay=true, pyramiding=1,
     process_orders_on_close=true, calc_on_every_tick=true,
     initial_capital=1000, currency = currency.USD, default_qty_value=10, 
     default_qty_type=strategy.percent_of_equity,
     commission_type=strategy.commission.percent, commission_value=0.1, slippage=2)

startDate = input(title="Start Date", type=input.integer,
     defval=1, minval=1, maxval=31, group="Backtesting range")
startMonth = input(title="Start Month", type=input.integer,
     defval=1, minval=1, maxval=12, group="Backtesting range")
startYear = input(title="Start Year", type=input.integer,
     defval=1900, minval=1800, maxval=2100, group="Backtesting range")
endDate = input(title="End Date", type=input.integer,
     defval=1, minval=1, maxval=31, group="Backtesting range")
endMonth = input(title="End Month", type=input.integer,
     defval=1, minval=1, maxval=12, group="Backtesting range")
endYear = input(title="End Year", type=input.integer,
     defval=2040, minval=1800, maxval=2100, group="Backtesting range")

// Date range filtering
inDateRange = (time >= timestamp(syminfo.timezone, startYear, startMonth, startDate, 0, 0)) and
     (time < timestamp(syminfo.timezone, endYear, endMonth, endDate, 23, 59))
     
fast = input(8, minval=8, title="Fast EMA", group="EMAs")
medium = input(14, minval=8, title="Medium EMA", group="EMAs")
slow = input(50, minval=8, title="Slow EMA", group="EMAs")
src = input(close, title="Source")

smoothK = input(3, "K", minval=1, group="Stoch-RSI", inline="K&D")
smoothD = input(3, "D", minval=1, group="Stoch-RSI", inline="K&D")
lengthRSI = input(14, "RSI Length", minval=1, group="Stoch-RSI", inline="length")
lengthStoch = input(14, "Stochastic Length", minval=1, group="Stoch-RSI", inline="length")
rsiSrc = input(close, title="RSI Source", group="Stoch-RSI")

length = input(title="Length", defval=14, minval=1, group="ATR")
smoothing = input(title="Smoothing", defval="RMA", options=["RMA", "SMA", "EMA", "WMA"], group="ATR")

// EMAs
fastema = ema(src, fast)
mediumema = ema(src, medium)
slowema = ema(src, slow)

// S-RSI
rsi1 = rsi(rsiSrc, lengthRSI)
k = sma(stoch(rsi1, rsi1, rsi1, lengthStoch), smoothK)
d = sma(k, smoothD)
sRsiCrossOver = k[1] < d[1] and k > d
sRsiCrossUnder = k[1] > d[1] and k < d

// ATR
ma_function(source, length) =>
	if smoothing == "RMA"
		rma(source, length)
	else
		if smoothing == "SMA"
			sma(source, length)
		else
			if smoothing == "EMA"
				ema(source, length)
			else
				wma(source, length)
atr = ma_function(tr(true), length)

// Trading Logic
longCond1 = (fastema > mediumema) and (mediumema > slowema)
longCond2 = true
// longCond2 = sRsiCrossOver
longCond3 = close > fastema
longCond4 = strategy.position_size <= 0
longCond = longCond1 and longCond2 and longCond3 and longCond4 and inDateRange

shortCond1 = (fastema < mediumema) and (mediumema < slowema)
shortCond2 = true 
// shortCond2 = sRsiCrossUnder
shortCond3 = close < fastema
shortCond4 = strategy.position_size >= 0
shortCond = shortCond1 and shortCond2 and shortCond3 and shortCond4 and inDateRange

var takeProfit = float(na), var stopLoss = float(na)
if longCond and strategy.position_size <= 0
    takeProfit := close + 4*atr
    stopLoss := close - 1*atr
    // takeProfit := close + 2*atr
    // stopLoss := close - 3*atr

else if shortCond and strategy.position_size >= 0
    takeProfit := close - 4*atr
    stopLoss := close + 1*atr
    // takeProfit := close - 2*atr
    // stopLoss := close + 3*atr
    
// Strategy calls
strategy.entry("3ESRA", strategy.long, comment="Long", when=longCond and strategy.position_size <= 0)
strategy.entry("3ESRA", strategy.short, comment="Short", when=shortCond and strategy.position_size >= 0)
strategy.exit(id="TP-SL", from_entry="3ESRA", limit=takeProfit, stop=stopLoss)
if (not inDateRange)
    strategy.close_all()
    
// Plot EMAs
plot(fastema, color=color.purple, linewidth=2, title="Fast EMA")
plot(mediumema, color=color.teal, linewidth=2, title="Medium EMA")
plot(slowema, color=color.yellow, linewidth=2, title="Slow EMA")
// Plot S-RSI
// plotshape((strategy.position_size > 0) ? na : sRsiCrossOver, title="StochRSI Cross Over", style=shape.triangleup, location=location.belowbar, color=color.teal, text="SRSI", size=size.small)
// Plot trade
bgcolor(strategy.position_size > 0 ? color.new(color.green, 75) : strategy.position_size < 0 ? color.new(color.red,75) : color(na))
// Plot Strategy
plot((strategy.position_size != 0) ? takeProfit : na, style=plot.style_linebr, color=color.green, title="TP")
plot((strategy.position_size != 0) ? stopLoss : na, style=plot.style_linebr, color=color.red, title="SL")



Больше