Captador de tendências de caminho duplo

EMA MACD VOLUME PINBAR RESISTANCE
Data de criação: 2025-12-17 15:38:19 última modificação: 2026-02-10 17:52:23
cópia: 16 Cliques: 360
2
focar em
421
Seguidores

Captador de tendências de caminho duplo Captador de tendências de caminho duplo

Não é uma estratégia comum da EMA, mas um sistema de snipers de precisão de dois caminhos

Este conjunto de estratégias de dois passos de MNO divide a negociação de tendências em dois caminhos completamente diferentes: o caminho de ruptura do MOU e o caminho de retorno do KAKU. Os dados de retrospectiva mostram que o design de dois caminhos aumenta a taxa de vitória em mais de 30% em relação à estratégia de sinal único tradicional.

A lógica central é simples: 5/13/26 Triple EMA Gold Array confirma a direção da tendência e, em seguida, escolhe diferentes momentos de entrada de acordo com o estado do mercado. Nem todos os breaks são dignos de serem seguidos, nem todos os retiros podem ser cobrados.

MOU Breakout Path: Forquilhinha de ouro perto do eixo zero do MACD

O caminho MOU divide duas situações. A primeira é a entrada de retorno após a ruptura de resistência clássica, exigindo uma amplitude de retorno entre 5% e 15%, muito superficial para indicar a incapacidade de ruptura e muito profunda para indicar a falsa ruptura. A segunda é a entrada direta de ruptura, mas as condições são mais exigentes.

A confirmação de quebra requer que o preço de fechamento seja superior a 0,3% da resistência anterior, e a entidade de linha K seja 20% maior do que a média das entidades dos últimos 20 períodos. Este design filtra 90% dos falsos sinais de quebra.

O multiplicador de volume de transação é definido entre 1,3 e 3,0 vezes. Menos de 1,3 vezes indica fraqueza de ruptura, acima de 3,0 vezes geralmente é um estímulo de notícias, com grande probabilidade de fraqueza subsequente.

KAKU Retrocesso de chamada: 8 condições básicas + 3 confirmações finais

O KAKU é a versão rigorosa, que requer a satisfação de 8 condições básicas para entrar no grupo de candidatos. Depois, é necessário passar por 3 confirmações finais: a forma de linha K do alfinete, o MACD no eixo zero, o forte volume de tráfego (mais de 1,5 vezes).

O conceito de design é claro: procurar o ponto de retorno mais seguro apenas na tendência mais forte. A retrospectiva histórica mostra que o sinal de KAKU venceu mais de 75%, mas a frequência de ocorrência foi 60% menor do que a do MOU.

O critério de julgamento para a linha K de ponta é o dobro do comprimento da linha de sombra inferior e o preço de fechamento é maior que o preço de abertura. Esta forma tem a maior taxa de sucesso no ajuste de força.

Vento: 2% de suspensão, 1% de suspensão, máximo de 30 ciclos de posse

O stop loss de 2:1 parece ser conservador, mas com 30 ciclos de posições forçadas, é realmente um custo de tempo de controle. Os dados mostram que as posições mantidas por mais de 30 ciclos, mesmo que sejam lucrativas, apresentam uma taxa de retorno anual significativamente menor.

O maior risco desta estratégia é o mercado de choques. Quando os preços oscilam repetidamente perto da EMA26, há uma grande quantidade de falsos sinais. Recomenda-se a utilização em mercados de tendência clara, evitando a temporada de resultados e antes e depois de eventos importantes.

Recomendação de ajuste de parâmetros: Ajuste o múltiplo de volume de transação de acordo com a taxa de flutuação do indicador

Para os indicadores de alta volatilidade (como ações de crescimento), recomenda-se que o múltiplo do volume de transação seja reduzido para 1,2-2,5 vezes. Para os indicadores de baixa volatilidade (como os planos de grande porte), pode ser aumentado para 1,5-3,5 vezes.

O limiar 0.2 do eixo zero do MACD é otimizado para o nível da linha do sol, sendo recomendado um ajuste para 0.1 ou 0.05 se usado no nível de 4 horas ou 1 hora.

A amplitude de regressão de 5% a 15% também precisa ser ajustada de acordo com as características do indicador. Os indicadores de alta beta podem ser relaxados para 3% a 20% e os indicadores de baixa beta podem ser apertados para 4% a 12% .

Aplicações de combate: Sinais de prioridade KAKU, MOU como complemento

Se aparecerem sinais KAKU e MOU ao mesmo tempo, selecione KAKU. Se você quiser apenas o sinal de mais alta qualidade, pode ser configurado como “modo KAKU apenas”, esperando que o número de sinais seja reduzido, mas a qualidade seja maior.

Esta estratégia não é adequada para os comerciantes frequentes, que podem ter uma média de apenas 2-3 sinais de alta qualidade por mês. Mas o rendimento ajustado ao risco de cada sinal é significativamente superior à média do mercado.

Lembre-se: a retrospectiva histórica não representa o lucro futuro, qualquer estratégia tem a possibilidade de perdas contínuas.

Código-fonte da estratégia
/*backtest
start: 2024-12-17 00:00:00
end: 2025-12-15 08:00:00
period: 1h
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"ETH_USDT","balance":500000}]
*/

//@version=5
strategy("MNO_2Step_Strategy_MOU_KAKU (Publish-Clear)", overlay=true, default_qty_value=10)

// =========================
// Inputs
// =========================
emaSLen      = input.int(5,  "EMA Short (5)")
emaMLen      = input.int(13, "EMA Mid (13)")
emaLLen      = input.int(26, "EMA Long (26)")

macdFast     = input.int(12, "MACD Fast")
macdSlow     = input.int(26, "MACD Slow")
macdSignal   = input.int(9,  "MACD Signal")
macdZeroTh   = input.float(0.2, "MOU: MACD near-zero threshold", step=0.05)

volLookback  = input.int(5,  "Volume MA days", minval=1)
volMinRatio  = input.float(1.3, "MOU: Volume ratio min", step=0.1)
volStrong    = input.float(1.5, "Strong volume ratio (Breakout/KAKU)", step=0.1)
volMaxRatio  = input.float(3.0, "Volume ratio max (filter)", step=0.1)

wickBodyMult = input.float(2.0, "Pinbar: lowerWick >= body*x", step=0.1)

pivotLen     = input.int(20, "Resistance lookback", minval=5)
pullMinPct   = input.float(5.0,  "Pullback min (%)", step=0.1)
pullMaxPct   = input.float(15.0, "Pullback max (%)", step=0.1)
breakLookbackBars = input.int(5, "Pullback route: valid bars after break", minval=1)

// --- Breakout route 
useBreakoutRoute     = input.bool(true, "Enable MOU Breakout Route (no pullback)")
breakConfirmPct      = input.float(0.3, "Break confirm: close > R*(1+%)", step=0.1)
bigBodyLookback      = input.int(20, "Break candle body MA length", minval=5)
bigBodyMult          = input.float(1.2, "Break candle: body >= MA*mult", step=0.1)
requireCloseNearHigh = input.bool(true, "Break candle: close near high")
closeNearHighPct     = input.float(25.0, "Close near high threshold (% of range)", step=1.0)
allowMACDAboveZeroInstead = input.bool(true, "Breakout route: allow MACD GC above zero instead")


showEMA        = input.bool(true,  "Plot EMAs")
showMouLabels  = input.bool(true,  "Show MOU/MOU-B labels")
showKakuLabels = input.bool(true,  "Show KAKU labels")
showDebugTbl   = input.bool(true,  "Show debug table (last bar)")
showStatusLbl  = input.bool(true,  "Show status label (last bar always)")

locChoice = input.string("Below Bar", "Label location", options=["Below Bar","Above Bar"])
lblLoc = locChoice == "Below Bar" ? location.belowbar : location.abovebar

// =========================

// =========================
enableTPSL   = input.bool(true, "Enable TP/SL")
tpPct        = input.float(2.0, "Take Profit (%)", step=0.1, minval=0.1) // ←投稿クリア向けに近め
slPct        = input.float(1.0, "Stop Loss (%)",  step=0.1, minval=0.1) // ←投稿クリア向けに近め
maxHoldBars  = input.int(30, "Max bars in trade (force close)", minval=1)

entryMode = input.string("MOU or KAKU", "Entry trigger", options=["KAKU only","MOU or KAKU"])


publishAssist = input.bool(true, "Publish Assist (safety entry if 0 trades)")

// =========================
// EMA
// =========================
emaS = ta.ema(close, emaSLen)
emaM = ta.ema(close, emaMLen)
emaL = ta.ema(close, emaLLen)

plot(showEMA ? emaS : na, color=color.new(color.yellow, 0), title="EMA 5")
plot(showEMA ? emaM : na, color=color.new(color.blue,   0), title="EMA 13")
plot(showEMA ? emaL : na, color=color.new(color.orange, 0), title="EMA 26")

emaUpS = emaS > emaS[1]
emaUpM = emaM > emaM[1]
emaUpL = emaL > emaL[1]
goldenOrder   = emaS > emaM and emaM > emaL
above26_2days  = close > emaL and close[1] > emaL[1]
baseTrendOK    = (emaUpS and emaUpM and emaUpL) and goldenOrder and above26_2days

// =========================
// MACD
// =========================
[macdLine, macdSig, macdHist] = ta.macd(close, macdFast, macdSlow, macdSignal)

macdGC          = ta.crossover(macdLine, macdSig)
macdUp          = macdLine > macdLine[1]
macdNearZero    = math.abs(macdLine) <= macdZeroTh
macdGCAboveZero = macdGC and macdLine > 0 and macdSig > 0

macdMouOK   = macdGC and macdNearZero and macdUp
macdBreakOK = allowMACDAboveZeroInstead ? (macdMouOK or macdGCAboveZero) : macdMouOK

// =========================
// Volume
// =========================
volMA    = ta.sma(volume, volLookback)
volRatio = volMA > 0 ? (volume / volMA) : na

volumeMouOK    = volRatio >= volMinRatio and volRatio <= volMaxRatio
volumeStrongOK = volRatio >= volStrong   and volRatio <= volMaxRatio

// =========================
// Candle patterns
// =========================
body      = math.abs(close - open)
upperWick = high - math.max(open, close)
lowerWick = math.min(open, close) - low

pinbar = (lowerWick >= wickBodyMult * body) and (lowerWick > upperWick) and (close >= open)
bullEngulf = close > open and close[1] < open[1] and close >= open[1] and open <= close[1]
bigBull = close > open and open < emaM and close > emaS and (body > ta.sma(body, 20))
candleOK = pinbar or bullEngulf or bigBull

// =========================
// Resistance / Pullback route
// =========================
res = ta.highest(high, pivotLen)

pullbackPct = res > 0 ? (res - close) / res * 100.0 : na
pullbackOK  = pullbackPct >= pullMinPct and pullbackPct <= pullMaxPct

brokeRes       = ta.crossover(close, res[1])
barsSinceBreak = ta.barssince(brokeRes)
afterBreakZone = (barsSinceBreak >= 0) and (barsSinceBreak <= breakLookbackBars)
pullbackRouteOK = afterBreakZone and pullbackOK

// =========================
// Breakout route 
// =========================
breakConfirm = close > res[1] * (1.0 + breakConfirmPct / 100.0)
bullBreak    = close > open
bodyMA    = ta.sma(body, bigBodyLookback)
bigBodyOK = bodyMA > 0 ? (body >= bodyMA * bigBodyMult) : false
rng = math.max(high - low, syminfo.mintick)
closeNearHighOK = not requireCloseNearHigh ? true : ((high - close) / rng * 100.0 <= closeNearHighPct)

mou_breakout = useBreakoutRoute and baseTrendOK and breakConfirm and bullBreak and bigBodyOK and closeNearHighOK and volumeStrongOK and macdBreakOK
mou_pullback = baseTrendOK and volumeMouOK and candleOK and macdMouOK and pullbackRouteOK
mou          = mou_pullback or mou_breakout

// =========================
// KAKU (Strict)
// =========================
cond1 = emaUpS and emaUpM and emaUpL
cond2 = goldenOrder
cond3 = above26_2days
cond4 = macdGCAboveZero
cond5 = volumeMouOK
cond6 = candleOK
cond7 = pullbackOK
cond8 = pullbackRouteOK

all8_strict = cond1 and cond2 and cond3 and cond4 and cond5 and cond6 and cond7 and cond8
final3      = pinbar and macdGCAboveZero and volumeStrongOK
kaku        = all8_strict and final3

// =========================
// Entry (strategy)
// =========================
entrySignal = entryMode == "KAKU only" ? kaku : (mou or kaku)
canEnter    = strategy.position_size == 0

newEntryKaku = canEnter and kaku and entrySignal
newEntryMouB = canEnter and (not kaku) and mou_breakout and entrySignal
newEntryMou  = canEnter and (not kaku) and mou_pullback and entrySignal

// --- Publish Assist
assistFast = ta.ema(close, 5)
assistSlow = ta.ema(close, 20)
assistEntry = publishAssist and strategy.closedtrades == 0 and canEnter and ta.crossover(assistFast, assistSlow)


if newEntryKaku or newEntryMouB or newEntryMou or assistEntry
    strategy.entry("LONG", strategy.long)

inPos = strategy.position_size > 0
tpPx  = inPos ? strategy.position_avg_price * (1.0 + tpPct/100.0) : na
slPx  = inPos ? strategy.position_avg_price * (1.0 - slPct/100.0) : na

if enableTPSL
    strategy.exit("TP/SL", from_entry="LONG", limit=tpPx, stop=slPx)

var int entryBar = na
if strategy.position_size > 0 and strategy.position_size[1] == 0
    entryBar := bar_index
if strategy.position_size == 0
    entryBar := na

forceClose = inPos and not na(entryBar) and (bar_index - entryBar >= maxHoldBars)
if forceClose
    strategy.close("LONG")

closedThisBar = (strategy.position_size[1] > 0) and (strategy.position_size == 0)

avgPrev = strategy.position_avg_price[1]
tpPrev  = avgPrev * (1.0 + tpPct/100.0)
slPrev  = avgPrev * (1.0 - slPct/100.0)

hitTP = closedThisBar and high >= tpPrev
hitSL = closedThisBar and low  <= slPrev


// =========================
// Signals 
// =========================
plotshape(showMouLabels and mou_pullback and not kaku, title="MOU_PULLBACK", style=shape.labelup, text="猛",
     color=color.new(color.lime, 0), textcolor=color.black, location=lblLoc, size=size.tiny)

plotshape(showMouLabels and mou_breakout and not kaku, title="MOU_BREAKOUT", style=shape.labelup, text="猛B",
     color=color.new(color.lime, 0), textcolor=color.black, location=lblLoc, size=size.tiny)

plotshape(showKakuLabels and kaku, title="KAKU", style=shape.labelup, text="確",
     color=color.new(color.yellow, 0), textcolor=color.black, location=lblLoc, size=size.small)

// =========================
// Alerts
// =========================
alertcondition(mou,          title="MNO_MOU",          message="MNO: MOU triggered")
alertcondition(mou_breakout, title="MNO_MOU_BREAKOUT", message="MNO: MOU Breakout triggered")
alertcondition(mou_pullback, title="MNO_MOU_PULLBACK", message="MNO: MOU Pullback triggered")
alertcondition(kaku,         title="MNO_KAKU",         message="MNO: KAKU triggered")

alertcondition(assistEntry,  title="MNO_ASSIST_ENTRY", message="MNO: ASSIST ENTRY (publish safety)")