Esta estratégia baseia-se na Adaptação da Média Móvel do Ehlers MESA e foi concebida como uma estratégia de negociação de tendências que segue dois cruzes de médias. Faz mais quando atravessas a linha lenta na linha rápida e fazes menos quando atravessas a linha lenta abaixo da linha rápida, uma estratégia típica de cruzamento de médias móveis duplas.
O núcleo desta estratégia é o cálculo de duas médias móveis adaptativas: a linha MAMA e a linha FAMA. Entre elas, a fórmula de cálculo da linha MAMA é a seguinte:
alpha = fl / dphase
alpha = iff(alpha < sl, sl, iff(alpha > fl, fl, alpha))
mama = alpha*src + (1 - alpha)*nz(mama[1])
A fl é a restrição rápida, a sl é a restrição lenta e a dphase é a diferença de fase.
A fórmula de cálculo da linha FAMA é a seguinte:
fama = .5*alpha*mama + (1 - .5*alpha)*nz(fama[1])
A linha FAMA é a linha de planeamento de ondas de baixa passagem da linha MAMA.
A estratégia usa a relação de tamanho entre a linha MAMA e a linha FAMA para determinar se a linha está em uma tendência ascendente ou descendente, gerando assim um sinal de negociação.
A estratégia tem as seguintes vantagens:
Usando a média móvel adaptável, os parâmetros são ajustados automaticamente de acordo com as mudanças do mercado, sem a necessidade de definir os parâmetros fixos manualmente.
Adição de filtros FAMA de baixa permeabilidade, que podem filtrar brechas falsas.
O design de duas médias móveis permite o acompanhamento de tendências de longo prazo.
A lógica da estratégia é simples e clara, fácil de entender e modificar.
Os indicadores de visualização são intuitivos e os sinais de negociação são claramente visíveis.
A estratégia também apresenta alguns riscos:
A estratégia de cruzamento de duas linhas é propensa a produzir sinais de negociação múltiplos e recomenda-se o controle adequado do intervalo e da retirada.
As linhas MAMA e FAMA são complexas de calcular, e a configuração incorreta dos parâmetros pode causar distorções na curva.
Os parâmetros de adaptação podem levar a otimização excessiva, e precisam ser validados em conjunto com outros indicadores técnicos.
O cruzamento de duas linhas tem um atraso de tempo e pode perder o ponto de mudança de tendência.
O risco de falhas de segurança é muito elevado.
A estratégia pode ser otimizada em várias direções:
Optimizar a configuração de parâmetros para encontrar a melhor combinação de parâmetros de restrição rápida e lenta.
Aumentar a estratégia de stop loss e controlar rigorosamente o stop loss individual.
Combinação com outros indicadores de filtragem de sinais, como MACD, RSI, etc, para evitar falsos breaks.
Aumentar os indicadores de tendência e evitar a negociação de contrapartida.
Otimizar o ritmo de entrada, ajustar os requisitos de intervalo de cruzamento de duas linhas e reduzir a transação excessivamente frequente.
Optimizar a estratégia de suspensão, tomando diferentes medidas de suspensão de acordo com a intensidade da tendência.
Teste as diferenças de configuração de parâmetros de diferentes variedades para encontrar a melhor combinação de parâmetros.
A estratégia global é uma estratégia típica de acompanhamento de tendências, que utiliza a média móvel adaptada do Ehlers MESA para construir um indicador de visualização e gerar sinais de negociação de forma binária. A estratégia possui vantagens como a adaptação dos parâmetros, a falsa ruptura da onda e a visualização, além de riscos como o atraso no tempo e a negociação múltipla.
/*backtest
start: 2023-09-20 00:00:00
end: 2023-09-27 00:00:00
period: 30m
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=2
// @author LazyBear
//
// List of my public indicators: http://bit.ly/1LQaPK8
// List of my app-store indicators: http://blog.tradingview.com/?p=970
//
strategy("Ehlers MESA Adaptive Moving Average [LazyBear with ekoronin fix]", shorttitle="EMAMA_LB (ekoronin fix)", overlay=false, calc_on_every_tick=true, precision=0)
src=input(close, title="Source")
fl=input(.4, title="Fast Limit")
sl=input(.04, title="Slow Limit")
pi = 3.1415926
sp = (4*src + 3*src[1] + 2*src[2] + src[3]) / 10.0
dt = (.0962*sp + .5769*nz(sp[2]) - .5769*nz(sp[4])- .0962*nz(sp[6]))*(.075*nz(p[1]) + .54)
q1 = (.0962*dt + .5769*nz(dt[2]) - .5769*nz(dt[4])- .0962*nz(dt[6]))*(.075*nz(p[1]) + .54)
i1 = nz(dt[3])
jI = (.0962*i1 + .5769*nz(i1[2]) - .5769*nz(i1[4])- .0962*nz(i1[6]))*(.075*nz(p[1]) + .54)
jq = (.0962*q1 + .5769*nz(q1[2]) - .5769*nz(q1[4])- .0962*nz(q1[6]))*(.075*nz(p[1]) + .54)
i2_ = i1 - jq
q2_ = q1 + jI
i2 = .2*i2_ + .8*nz(i2[1])
q2 = .2*q2_ + .8*nz(q2[1])
re_ = i2*nz(i2[1]) + q2*nz(q2[1])
im_ = i2*nz(q2[1]) - q2*nz(i2[1])
re = .2*re_ + .8*nz(re[1])
im = .2*im_ + .8*nz(im[1])
//p1 = iff(im!=0 and re!=0, 360/atan(im/re), nz(p[1]))
p1 = iff(im!=0 and re!=0, 2*pi/atan(im/re), nz(p[1]))
p2 = iff(p1 > 1.5*nz(p1[1]), 1.5*nz(p1[1]), iff(p1 < 0.67*nz(p1[1]), 0.67*nz(p1[1]), p1))
p3 = iff(p2<6, 6, iff (p2 > 50, 50, p2))
p = .2*p3 + .8*nz(p3[1])
spp = .33*p + .67*nz(spp[1])
//phase = atan(q1 / i1)
phase = 180/pi * atan(q1 / i1)
dphase_ = nz(phase[1]) - phase
dphase = iff(dphase_< 1, 1, dphase_)
alpha_ = fl / dphase
alpha = iff(alpha_ < sl, sl, iff(alpha_ > fl, fl, alpha_))
mama = alpha*src + (1 - alpha)*nz(mama[1])
fama = .5*alpha*mama + (1 - .5*alpha)*nz(fama[1])
//pa=input(false, title="Mark crossover points")
//plotarrow(pa?(cross(mama, fama)?mama<fama?-1:1:na):na, title="Crossover Markers")
//fr=input(false, title="Fill MAMA/FAMA Region")
//duml=plot(fr?(mama>fama?mama:fama):na, style=circles, color=gray, linewidth=0, title="DummyL")
//mamal=plot(mama, title="MAMA", color=red, linewidth=2)
//famal=plot(fama, title="FAMA", color=green, linewidth=2)
//fill(duml, mamal, red, transp=70, title="NegativeFill")
//fill(duml, famal, green, transp=70, title="PositiveFill")
//ebc=input(false, title="Enable Bar colors")
//bc=mama>fama?lime:red
//barcolor(ebc?bc:na)
longSpike=mama>fama? 1:0
shortSpike=mama<fama? 1:0
plot(longSpike, title = "Mama Long", style=line, linewidth=1, color=yellow)
plot(shortSpike, title = "Mama Short", style=line, linewidth=1, color=red)
//possig = iff(reverse and pos == 1, -1,
// iff(reverse and pos == -1, 1, pos))
if (longSpike)
strategy.entry("Long", strategy.long)
if (shortSpike)
strategy.entry("Short", strategy.short)