
Cette stratégie permet de déterminer la direction de la tendance actuelle en calculant le rapport de la longueur de l’ombre du soleil de la ligne K. Elle est utilisée pour identifier la tendance en fonction de l’amplitude réelle moyenne de l’ATR. Elle permet d’ouvrir des positions inversées au point de rupture, de définir des arrêts de perte et de capturer la tendance à court terme.
La stratégie consiste principalement à calculer le rapport entre la longueur de l’ombre du soleil et la longueur de la ligne K pour déterminer la direction de la tendance actuelle, soit une tendance à la baisse lorsque la longueur de la ligne du soleil est trop longue, soit une tendance à la hausse lorsque la longueur de la ligne du soleil est trop longue.
La logique de la stratégie est la suivante:
C’est la logique de base de la stratégie, qui consiste à ouvrir des positions inverses en identifiant les points de rupture de la tendance et à optimiser les gains après avoir défini un stop-loss.
Le risque peut être maîtrisé par un arrêt raisonnable, des paramètres d’optimisation et un arrêt rapide.
Les stratégies peuvent être optimisées dans les domaines suivants:
L’efficacité de la stratégie peut être maximisée par des tests et des optimisations à plusieurs niveaux.
Dans l’ensemble, la stratégie est une stratégie de rupture de courte ligne qui est stable en termes d’efficacité. Une fois optimisée, elle peut devenir une partie essentielle du trading quantitatif.
/*backtest
start: 2022-11-08 00:00:00
end: 2023-11-14 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © ondrej17
//@version=4
strategy("longWickstrategy", overlay=true )
// Inputs
st_yr_inp = input(defval=2020, title='Backtest Start Year')
st_mn_inp = input(defval=01, title='Backtest Start Month')
st_dy_inp = input(defval=01, title='Backtest Start Day')
en_yr_inp = input(defval=2025, title='Backtest End Year')
en_mn_inp = input(defval=01, title='Backtest End Month')
en_dy_inp = input(defval=01, title='Backtest End Day')
sltp_inp = input(defval=0.8, title='N - % offset for N*SL and (2N)*TP')/100
// Dates
start = timestamp(st_yr_inp, st_mn_inp, st_dy_inp,00,00)
end = timestamp(en_yr_inp, en_mn_inp, en_dy_inp,00,00)
canTrade = time >= start and time <= end
// Indicators Setup
// Strategy Calcuations
lowerWick = (open > close) ? close-low : open - low
upperWick = (open > close) ? high-open : high-close
wickLength = max(lowerWick,upperWick)
candleLength = high-low
wickToCandleRatio = wickLength / candleLength
entryFilterCandleLength = candleLength > 0.75*atr(48)
// Entries and Exits
longCondition = entryFilterCandleLength and wickToCandleRatio > 0.5 and lowerWick > upperWick and canTrade and strategy.position_size == 0
shortCondition = entryFilterCandleLength and wickToCandleRatio > 0.5 and lowerWick < upperWick and canTrade and strategy.position_size == 0
strategy.entry("pendingLong", strategy.long, limit=low+wickLength/2, when = longCondition)
strategy.entry("pendingShort", strategy.short, limit=high-wickLength/2, when = shortCondition)
longStop = strategy.position_size > 0 ? strategy.position_avg_price*(1-sltp_inp) : na
longTP = strategy.position_size > 0 ? strategy.position_avg_price*(1+2*sltp_inp) : na
shortStop = strategy.position_size < 0 ? strategy.position_avg_price*(1+sltp_inp) : na
shortTP = strategy.position_size < 0 ? strategy.position_avg_price*(1-2*sltp_inp) : na
strategy.exit("longSLTP","pendingLong", stop=longStop, limit = longTP)
strategy.exit("shortSLTP","pendingShort", stop=shortStop, limit = shortTP)
plot(longStop, color=color.red, style=plot.style_linebr, linewidth=2)
plot(shortStop, color=color.red, style=plot.style_linebr, linewidth=2)
plot(longTP, color=color.green, style=plot.style_linebr, linewidth=2)
plot(shortTP, color=color.green, style=plot.style_linebr, linewidth=2)
plotLongCondition = longCondition ? high+abs(open-close) : na
plot(plotLongCondition, style=plot.style_circles, linewidth=4, color=color.green)
plotShortCondition = shortCondition ? high+abs(open-close) : na
plot(plotShortCondition, style=plot.style_circles, linewidth=4, color=color.red)