이 전략은 엘더스 포스 인덱스 (EFI) 를 기반으로 한 양적 거래 시스템으로, 신호 발생을 위해 표준 편차와 이동 평균을 결합하고, 동적 스톱 로스 및 영리 포지셔닝을 위해 ATR을 사용합니다. 이 전략은 빠르고 느린 EFI 지표를 계산하고 표준 편차를 사용하여 정상화하고 크로스 오버 분석을 통해 거래 신호를 생성하여 완전한 거래 시스템을 만듭니다. 더 높은 수익을 추구하면서 위험을 효과적으로 제어하기 위해 동적 스톱 로스 및 트레일링 영리 메커니즘을 사용합니다.
이 전략은 몇 가지 핵심 요소에 기반합니다.
이 전략은 EFI 지표, 표준편차 및 ATR를 결합하여 완전한 거래 시스템을 구축합니다. 이 전략의 강점은 높은 신호 신뢰성과 합리적인 위험 통제에 있습니다. 그러나 여전히 다른 시장 환경에 대한 최적화가 필요합니다. 시장 상태 평가, 볼륨 필터링 및 기타 메커니즘을 추가하여 전략의 안정성과 수익성이 더욱 향상 될 수 있습니다. 전반적으로 실용적인 가치와 함께 탄탄한 양적 거래 프레임워크를 제공합니다.
/*backtest start: 2019-12-23 08:00:00 end: 2024-11-27 00:00:00 period: 1d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Elder's Force Index Strategy with ATR-Based SL and TP", overlay=true) // Input parameters for fast and long EFI efi_fast_length = input.int(13, "Fast EFI Length", minval=1) efi_long_length = input.int(50, "Long EFI Length", minval=1) stdev_length = input.int(50, "Standard Deviation Length", minval=2, maxval=300) numdev = input.float(2, "Number of Deviations", minval=1, maxval=20, step=0.1) atr_length = input.int(14, "ATR Length", minval=1) atr_multiplier_sl = input.float(1.5, "ATR Multiplier for Stop Loss", step=0.1) trailing_tp_multiplier = input.float(0.5, "Multiplier for Trailing Take Profit", step=0.1) // Elder's Force Index Calculation for Fast and Long EFI efi_fast = ta.ema((close - close[1]) * volume, efi_fast_length) efi_long = ta.ema((close - close[1]) * volume, efi_long_length) // Calculate Standard Deviation for Fast EFI efi_fast_average = ta.sma(efi_fast, stdev_length) efi_fast_stdev = ta.stdev(efi_fast, stdev_length) efi_fast_diff = efi_fast - efi_fast_average efi_fast_result = efi_fast_diff / efi_fast_stdev // Calculate Standard Deviation for Long EFI efi_long_average = ta.sma(efi_long, stdev_length) efi_long_stdev = ta.stdev(efi_long, stdev_length) efi_long_diff = efi_long - efi_long_average efi_long_result = efi_long_diff / efi_long_stdev // Define upper and lower standard deviation levels upper_sd = numdev lower_sd = -numdev // Define entry conditions based on crossing upper and lower standard deviations long_condition = efi_fast_result > upper_sd and efi_long_result > upper_sd short_condition = efi_fast_result < lower_sd and efi_long_result < lower_sd // Check if a position is already open is_position_open = strategy.position_size != 0 // Calculate ATR for stop loss and take profit atr = ta.atr(atr_length) // Initialize stop loss and take profit variables var float stop_loss = na var float take_profit = na // Execute trades based on conditions, ensuring only one trade at a time if (long_condition and not is_position_open) strategy.entry("Long", strategy.long) stop_loss := close - atr * atr_multiplier_sl // Set initial stop loss based on ATR take_profit := close + atr * trailing_tp_multiplier // Set initial take profit based on ATR if (short_condition and not is_position_open) strategy.entry("Short", strategy.short) stop_loss := close + atr * atr_multiplier_sl // Set initial stop loss based on ATR take_profit := close - atr * trailing_tp_multiplier // Set initial take profit based on ATR // Update exit conditions if (is_position_open) // Update stop loss for trailing if (strategy.position_size > 0) // For long positions stop_loss := math.max(stop_loss, close - atr * atr_multiplier_sl) // Adjust take profit based on price movement take_profit := math.max(take_profit, close + atr * trailing_tp_multiplier) else if (strategy.position_size < 0) // For short positions stop_loss := math.min(stop_loss, close + atr * atr_multiplier_sl) // Adjust take profit based on price movement take_profit := math.min(take_profit, close - atr * trailing_tp_multiplier) // Set exit conditions strategy.exit("Long Exit", from_entry="Long", stop=stop_loss, limit=take_profit) strategy.exit("Short Exit", from_entry="Short", stop=stop_loss, limit=take_profit)