이동 평균을 기반으로 한 원래의 추세 추종 전략


생성 날짜: 2023-11-23 15:54:37 마지막으로 수정됨: 2023-11-23 15:54:37
복사: 0 클릭수: 581
avatar of ChaoZhang ChaoZhang
1
집중하다
1617
수행원

이동 평균을 기반으로 한 원래의 추세 추종 전략

개요

이 전략은 candle의 실물 부분을 기반으로, EMA 지표와 결합하여 시장 추세 방향을 판단하여 ORIGINAL PRIMITIVE TREND TRACKING의 효과를 구현합니다. 큰 선이있을 때 더 많이하고, 큰 선이있을 때 공백을 만들고, 시장 추세를 추적합니다.

전략 원칙

  1. 마지막 30개의 K 선의 candle 개체 평균 길이를 계산 sbody
  2. 최신 K 선이 일선이고, 개체 길이가 sbody/2보다 크면, 더 많이 한다.
  3. 더할 때, 만약 최신 K 선이 음선이고, 개체 길이가 sbody/2보다 크고, 현재 포지션은 이윤 상태라면 평다다 포지션
  4. 최신 K 선이 음선이고, 개체 길이가 sbody/2보다 크면 공백을 만든다.
  5. 공백이 되면, 만약 최신 K 선이 양선이고, 실체 길이가 sbody/2보다 크고, 현재 포지션은 수익 상태라면, 공백 포지션

우위 분석

이 전략은 다음과 같은 장점을 가지고 있습니다.

  1. 원시적인 것, 단순하고, 이해하기 쉽고, 실행하기 쉬운 것
  2. 캔들 구조를 통해 판단하면, Trading Breakouts에 대한 영향이 있습니다.
  3. 트렌드를 추적하여 더 큰 상황을 파악할 수 있습니다.
  4. 이윤 포지션 후 급속한 손실, 이윤 고정에 유리하다

위험 분석

이 전략에는 몇 가지 위험도 있습니다.

  1. 가짜 침입을 효과적으로 차단하지 못해 불필요한 손실을 초래할 수 있습니다.
  2. 촛불로 판단하는 것만으로도 슬라이드 포인트와 야간 비행에 취약합니다.
  3. 거래 빈도가 너무 높다는 것은 고려되지 않았습니다.

위험은 다음과 같은 방법으로 줄일 수 있습니다.

  1. 다른 지표와 결합하여 필터링 신호
  2. Stop Loss 전략 설정
  3. 최적화 매개 변수, 거래 빈도 제어

최적화 방향

이 정책은 다음과 같은 측면에서 최적화될 수 있습니다.

  1. 은 돌파구를 추가하고 가짜 돌파구를 필터링합니다.
  2. 단편적 손실을 줄이기 위한 손실을 막는 전략을 강화
  3. 트렌드 지표와 함께 트렌드 방향을 검사합니다
  4. 변수 최적화, 최적의 변수 조합을 찾는 것

요약하다

이 전략은 원시적인 간단한 유형의 트렌드 추적 전략에 속한다. 촛불 구조 판단을 통해 트렌드 방향을 효과적으로 추적할 수 있다. 동시에 빠른 스톱 로스 메커니즘을 설정하여 수익을 잠금할 수 있다. 이 전략은 트렌드 추적 포트폴리오를 보완할 수 있지만 위험을 줄이기 위해 여전히 최적화해야 한다.

전략 소스 코드
/*backtest
start: 2023-10-23 00:00:00
end: 2023-11-22 00:00:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=3
strategy(title = "Noro's Primitive Strategy v1.0", shorttitle = "Primitive str 1.0", overlay=true, default_qty_type = strategy.percent_of_equity, default_qty_value = 100.0, pyramiding = 10)

//Settings
needlong = input(true, defval = true, title = "Long")
needshort = input(true, defval = true, title = "Short")
usebody = input(true, defval = true, title = "Use body")
useus = input(true, defval = true, title = "Use UUP")
fromyear = input(1900, defval = 1900, minval = 1900, maxval = 2100, title = "From Year")
toyear = input(2100, defval = 2100, minval = 1900, maxval = 2100, title = "To Year")
frommonth = input(01, defval = 01, minval = 01, maxval = 12, title = "From Month")
tomonth = input(01, defval = 01, minval = 01, maxval = 12, title = "To Month")
fromday = input(01, defval = 01, minval = 01, maxval = 31, title = "From day")
today = input(31, defval = 31, minval = 01, maxval = 31, title = "To day")

//Logic
body = abs(close - open)
sbody = ema(body, 30) / 2
bar = close > open ? 1 : close < open ? -1 : 0

//Signals
up = bar == -1 and (body > sbody or usebody == false) and (close < strategy.position_avg_price or strategy.position_size <= 0 or useus == false)
dn = bar == 1 and (body > sbody or usebody == false) and (close > strategy.position_avg_price or strategy.position_size >= 0 or useus == false)

//Trading
if up
    strategy.entry("Long", strategy.long, needlong == false ? 0 : na, when=(time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 00, 00)))

if dn
    strategy.entry("Short", strategy.short, needshort == false ? 0 : na, when=(time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 00, 00)))
    
if time > timestamp(toyear, tomonth, today, 00, 00)
    strategy.close_all()