지수 이동 평균 교차 전략


생성 날짜: 2023-10-17 16:55:10 마지막으로 수정됨: 2023-10-17 16:55:10
복사: 0 클릭수: 719
avatar of ChaoZhang ChaoZhang
1
집중하다
1617
수행원

지수 이동 평균 교차 전략

개요

이것은 두 개의 다른 시간 주기에서 지수 이동 평균을 교차하여 다공개하는 자동 거래 전략이다. 그것은 간단한 기술 지표를 사용하여 초보자 학습과 연습에 적합하다.

원칙

이 전략은 두 개의 지수 이동 평균을 사용한다. 하나는 큰 시간 주기 평균이고, 하나는 현재 주기 평균이다. 현재 주기 평균선 위에 큰 주기 평균선을 통과할 때, 더 많이 하고, 현재 주기 평균선 아래에 큰 주기 평균선을 통과할 때, 공백을 한다.

특히, 전략은 두 개의 평균선 변수를 먼저 정의합니다.

  1. tf - 큰 시간 주기, 기본 일선
  2. len - 평균주기 길이는 기본 3

그리고 두 개의 EMA를 각각 계산합니다.

  1. ma1 - 대주기 일선의 3일 EMA
  2. ma2 - 현재 주기의 3일 EMA

마지막으로, 거래 논리:

  • ma2>ma1이 되면 더 많이 해야 합니다.
  • ma2 < ma1 이면 공백을 둡니다.

이렇게 하면, 다른 시간 주기 평균선의 교차를 통해 트렌드 방향을 판단하여 자동으로 거래할 수 있다.

장점

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

  1. 원리는 간단하고, 이해하기 쉽고, 구현하기 쉬우며, 초보자 학습에 매우 적합하다.
  2. 트렌드를 따라 거래하면 더 좋은 수익을 얻을 수 있습니다.
  3. 지수 이동 평균을 사용하여 가격 변화에 더 민감하여 트렌드 전환을 적시에 잡을 수 있습니다.
  4. 서로 다른 주기평균선의 조합으로 각자의 장점을 발휘하여 시스템의 안정성을 높일 수 있다.
  5. 너무 많은 매개 변수가 필요없고, 테스트 및 최적화가 쉬우며, 실디 디스크 운영이 편리하다.

위험

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

  1. 트렌드 추적이 어렵고, 시장의 변동으로 인해 감옥에 갇힐 수도 있다.
  2. 이중 평행선 교차는 지연되어 일부 기회를 놓칠 수 있습니다.
  3. 두 평행선 사이의 교차적 불순서를 효과적으로 필터링할 수 없는 경우.
  4. 단순한 평균선으로 복잡한 시장에 적응하기 힘들다.

스톱로스를 설정하거나, 변수 조합을 최적화하거나, 다른 지표를 추가하는 등의 방법으로 위험을 줄일 수 있다.

최적화 방향

이 전략은 다음과 같은 부분에서 최적화될 수 있습니다.

  1. 다양한 대주기 평균선 변수를 테스트하여 최적의 조합을 찾습니다.
  2. 트랜스포메이션을 필터링하여 잘못된 신호를 방지합니다.
  3. 트렌드 지표와 결합하여 포지션 강도 및 운영 효율성을 향상시킵니다.
  4. 단편적 손실을 통제하기 위해 적응적 스톱포인트를 설정하십시오.
  5. 포지션 관리를 최적화하고 시장에 따라 포지션 크기를 조정합니다.
  6. 기계학습 모형에 참여하여 전략을 더 똑똑하게 만들 수 있습니다.

요약하다

이 지수 이동 평균 교차 전략은 간단한 지수 캡처 트렌드를 적용하여 초보자 학습 연습에 적합합니다. 최적화 공간이 넓고, 더 많은 기술적 지표와 모델을 도입하여 더 강력한 효과의 정량 거래 전략을 개발할 수 있습니다.

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

//@version=3
strategy("Noro's Singapore Strategy", shorttitle = "Singapore str", overlay = true, default_qty_type = strategy.percent_of_equity, default_qty_value = 100, pyramiding = 0)

//Settings
needlong = input(true, defval = true, title = "Long")
needshort = input(true, defval = true, title = "Short")
capital = input(100, defval = 100, minval = 1, maxval = 10000, title = "Lot")
tf = input("D", title = "Big Timeframe")
len = input(3, minval = 1, title = "MA length")
src = input(close, title = "MA Source")
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(12, defval = 12, 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")

//MAs
ma1 = request.security(syminfo.tickerid, tf, sma(src, len))
ma2 = sma(src, len)
plot(ma1, linewidth = 2, color = blue, title = "Big TF MA")
plot(ma2, linewidth = 2, color = red, title = "MA")

//Trading
size = strategy.position_size
lot = 0.0
lot := size != size[1] ? strategy.equity / close * capital / 100 : lot[1]

if ma2 > ma1
    strategy.entry("L", strategy.long, needlong ? lot : 0, when = (time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 23, 59)))
if ma2 < ma1
    strategy.entry("S", strategy.short, needshort ? lot : 0, when = (time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 23, 59)))
if time > timestamp(toyear, tomonth, today, 23, 59)
    strategy.close_all()