
그림자 거래 전략은 K선에서 긴 하향 그림자 또는 긴 상향 그림자의 K선이 나타나는 것을 식별하여 시장이 역전될 수있는 시점을 판단합니다. 긴 하향 그림자 라인을 식별 할 때, 더 많은 것을하십시오. 긴 상향 그림자 라인을 식별 할 때, 공백하십시오. 이 전략은 주로 긴 그림자 라인이 역전되는 일반적인 법칙을 사용하여 거래합니다.
그림자 거래 전략의 핵심 논리는 K선에서 나타나는 긴 상도선과 긴 하도선이다. 전략은 K선 개체 크기를 계산하여corpo그림자 크기와pinnaL、pinnaS그림자 선의 크기가 개체 크기의 일정한 배가 될 때, 회전 기회가 발생할 수 있다고 생각한다. 구체적으로, 전략은 다음과 같은 단계를 포함한다:
corpo, 즉, 오픈 가격과 클로징 가격의 절대값.pinnaL, 즉 최고 가격과 종식 가격의 차이의 절대값.pinnaS, 즉, 최저 가격과 종식 가격의 절대 값.pinnaL > (corpo*size),size은 조정 가능한 변수입니다.pinnaS > (corpo*size)。이 전략은 또한 K선 변동의 크기를 판단합니다.dim최소값보다 크거나 크지 않은 경우min필터링을 통해 너무 작은 파동의 불쾌한 K선을 제거하십시오. 입구 후 스톱 손실과 스톱 탈퇴를 설정하십시오.
그림자 거래 전략은 비교적 간단하고 실용적인 짧은 선 거래 전략이다. 그것은 긴 그림자 선의 반전의 일반적인 법칙을 활용하여 거래 신호를 생성한다. 이 전략의 논리는 간단하고 구현하기 쉽고, 품종 차이에 따라 조정 및 최적화 할 수 있다. 동시에, 그림자 거래 전략에는 약간의 위험이 있으며, 추세와 다른 요소와 결합하여 필터링을 수행하여 잘못된 거래 가능성을 줄여야 한다.
/*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)