
A estratégia de negociação de sombra, através da identificação de uma linha de K com uma linha de sombra longa ou uma linha de K com uma linha de sombra longa, para determinar o momento em que o mercado pode se inverter. Quando a linha de sombra longa é identificada, faça mais; quando a linha de sombra longa é identificada, faça um vazio.
A lógica central da estratégia de negociação de sombras é identificar as sombras superiores e inferiores que aparecem na linha K. A estratégia é calculada através do tamanho da entidade da linha K.corpoe o tamanho da linha de sombrapinnaL、pinnaSQuando o tamanho da linha de sombra é maior do que um determinado número de vezes o tamanho da entidade, considera-se que pode haver uma oportunidade de reversão. Concretamente, a estratégia inclui os seguintes passos:
corpo, que é o valor absoluto da diferença entre o preço de abertura e o preço de fechamento.pinnaL, ou seja, o valor absoluto da diferença entre o preço máximo e o preço de fechamento.pinnaS, que é o valor absoluto da diferença entre o preço mínimo e o preço de fechamento.pinnaL > (corpo*size),sizeÉ um parâmetro ajustável.pinnaS > (corpo*size)。Além disso, a estratégia determina o tamanho das flutuações da linha K.dimSe é maior do que o mínimominA fim de eliminar as linhas K pouco interessantes, que são muito pequenas para oscilação. Depois de entrar, configure o stop loss e o stop exit.
A estratégia de negociação de sombra é uma estratégia de negociação de linhas curtas, mais simples e prática. Ela usa a lei universal da inversão de linhas longas para gerar sinais de negociação. A lógica da estratégia é simples, fácil de implementar e pode ser ajustada e otimizada de acordo com as diferenças de variedade.
/*backtest
start: 2023-10-01 00:00:00
end: 2023-10-11 23:59:59
period: 10m
basePeriod: 1m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=2
strategy("Shadow Trading", overlay=true)
size = input(1,type=float)
pinnaL = abs(high - close)
pinnaS = abs(low-close)
scarto = input(title="Tail Tollerance", type=float, defval=0.0018)
corpo = abs(close - open)
dim = abs(high-low)
min = input(0.001)
shortE = (open + dim)
longE = (open - dim)
barcolor(dim > min and (close > open) and (pinnaL > (corpo*size)) and (open-low<scarto) ? navy : na)
longcond = (dim > min) and (close > open) and (pinnaL > (corpo*size)) and (open-low<scarto)
minimo=low+scarto
massimo=high+scarto
barcolor( dim > min and(close < open) and (pinnaS > (corpo*size)) and (high-open<scarto) ? orange: na)
shortcond = (dim > min) and(close < open) and (pinnaS > (corpo*size)) and (high-open<scarto)
//plot(shortE)
//plot(longE)
//plot(open)
ss= shortcond ? close : na
ll=longcond ? close : na
offset= input(0.00000)
DayClose = 2
closup = barssince(change(strategy.opentrades)>0) >= DayClose
longCondition = (close > open) and (pinnaL > (corpo*size)) and (open-low<scarto)
crossFlag = longcond ? 1 : 0
monthBegin = input(1,maxval = 12)
yearBegin = input(2013, maxval= 2015, minval=2000)
if(month(time)>monthBegin and year(time) >yearBegin)
if (longcond)
strategy.entry("short", strategy.short, stop = low - offset)
//strategy.close("short", when = closup)
shortCondition = (close < open) and (pinnaS > (corpo*size)) and (high-open<scarto)
if(month(time)>monthBegin and year(time) >yearBegin)
if (shortcond)
strategy.entry("long", strategy.long, stop = high + offset)
//strategy.close("long", when = closup)
Target = input(20)
Stop = input(70) //- 2
Trailing = input(0)
CQ = 100
TPP = (Target > 0) ? Target*10: na
SLP = (Stop > 0) ? Stop*10 : na
TSP = (Trailing > 0) ? Trailing : na
strategy.exit("Close Long", "long", qty_percent=CQ, profit=TPP, loss=SLP, trail_points=TSP)
strategy.exit("Close Short", "short", qty_percent=CQ, profit=TPP, loss=SLP, trail_points=TSP)