Esta estratégia opera com base numa combinação de médias móveis de Hull e comparação diária de velas, com limiares de julgamento para condições longas/cortas.
Estratégia lógica:
Calcular os MAs duplos do casco e comparar o valor actual com o do período anterior.
Calcular a taxa de variação diária próxima e fixar limiares de julgamento longo/curto.
Vai longo quando a MA rápida cruza acima da MA lenta, e a variação diária excede o limiar.
Usar o stop loss fixo e os preços de lucro.
Pode também definir o limite máximo de posição aberta.
Vantagens:
O HullMA duplo melhora a precisão, a mudança diária confirma o viés.
Os limiares evitam ser influenciados por pequenos movimentos de contra-tendência.
SL/TP ajuda a garantir lucros e controlar riscos.
Riscos:
As configurações de limiar ruins podem perder oportunidades.
Fixado SL/TP Incapaz de ajustar de forma flexível, corre o risco de configurações inadequadas.
Tanto o Hull MA como o atraso da mudança diária.
Em resumo, este sistema de avaliação de dois indicadores com controlos de risco pode melhorar a estabilidade até certo ponto.
/*backtest start: 2022-09-06 00:00:00 end: 2023-02-21 00:00:00 period: 5d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=2 // Hull_MA_cross & Daily_Candle_cross combination with TP$ & SL$ setting // (new script reducing effect of repaint on results) // strategy("Decision Threshold", shorttitle="DT", overlay=true, default_qty_type=strategy.percent_of_equity, max_bars_back=720, default_qty_value=100, calc_on_order_fills= true, calc_on_every_tick=true, pyramiding=0) keh=input(title="Double HullMA",defval=14, minval=1) dt = input(defval=0.0010, title="Decision Threshold", step=0.0001) SL = input(defval=-50000.00, title="Stop Loss in $", step=1) TP = input(defval=100000.00, title="Target Point in $", step=1) p=input(ohlc4) ot=1 n2ma=2*wma(p,round(keh/2)) nma=wma(p,keh) diff=n2ma-nma sqn=round(sqrt(keh)) n2ma1=2*wma(p[1],round(keh/2)) nma1=wma(p[1],keh) diff1=n2ma1-nma1 sqn1=round(sqrt(keh)) n1=wma(diff,sqn) n2=wma(diff1,sqn) b=n1>n2?lime:red c=n1>n2?green:red d=n1>n2?red:green a1=plot(n1,color=c) a2=plot(n2,color=c) plot(cross(n1, n2) ? n1 : na, style = circles, color=b, linewidth = 4) plot(cross(n1, n2) ? n1 : na, style = line, color=d, linewidth = 4) confidence=(security(syminfo.tickerid, 'D', p)-security(syminfo.tickerid, 'D', p[1]))/security(syminfo.tickerid, 'D', p[1]) closelong = n1<n2 and p<n2 and confidence<dt or strategy.openprofit<SL or strategy.openprofit>TP if (closelong) strategy.close("Long") closeshort = n1>n2 and p>n2 and confidence>dt or strategy.openprofit<SL or strategy.openprofit>TP if (closeshort) strategy.close("Short") longCondition = n1>n2 and strategy.opentrades<ot and confidence>dt and p>n2 if (longCondition) strategy.entry("Long",strategy.long) shortCondition = n1<n2 and strategy.opentrades<ot and confidence<dt and p<n2 if (shortCondition) strategy.entry("Short",strategy.short)