이 전략은 피보나치 회귀 이론에 기반한 적응형 다단계 거래 시스템이다. 이는 피보나치 회귀 수준을 사용하여 시장의 중요한 지지 및 저항 지점을 식별하고 가격과 이러한 수준과의 상호 작용에 따라 거래 신호를 생성한다. 이 전략의 핵심은 시장 조건과 개인 선호에 따라 거래자가 회귀 주기, 피보나치 회귀 방향 및 입수 수준과 같은 중요한 매개 변수를 조정할 수 있도록하는 유연성이다.
이 전략의 핵심 논리는 다음과 같은 단계로 이루어져 있습니다.
전략의 독특한 점은 사용자가 피보나치 계산의 방향을 선택할 수 있다는 것입니다. (최고에서 아래로 또는 아래에서 위로) 구매 및 판매 신호에 대해 다른 피보나치 수준을 선택할 수 있습니다. 이러한 유연성은 전략이 다른 시장 환경과 거래 스타일에 적응할 수 있도록합니다.
이러한 위험을 완화하기 위해, 다음과 같은 것을 고려할 수 있습니다:
이러한 최적화는 전략의 적응성과 안정성을 크게 향상시킬 수 있으며, 이를 통해 보다 광범위한 시장 조건에서 효과를 유지할 수 있습니다.
피보나치 회귀를 기반으로 한 적응형 다단계 거래 전략은 금융 시장에서 잠재적인 거래 기회를 식별하는 데 필요한 유연하고 사용자 정의 가능한 프레임 워크를 제공합니다. 클래식 기술 분석 원칙과 현대적 위험 관리 기술을 결합하여 이 전략은 거래자에게 다양한 시장 환경에서 높은 확률의 거래 기회를 찾을 수있는 강력한 도구를 제공합니다. 그러나 모든 거래 전략과 마찬가지로 모든 것을 다룰 수 없습니다.
/*backtest
start: 2024-08-26 00:00:00
end: 2024-09-24 08:00:00
period: 4h
basePeriod: 4h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Simple Fibonacci Retracement Strategy", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=10)
// Input period for high and low points identification
lookback = input.int(100, title="Lookback Period", minval=10)
// Input to choose Fibonacci calculation direction
fib_direction = input.string(title="Fibonacci Direction", defval="Top to Bottom", options=["Top to Bottom", "Bottom to Top"])
// Input for Fibonacci levels
fib_level_236 = input.float(0.236, title="Fib 23.6% Level")
fib_level_382 = input.float(0.382, title="Fib 38.2% Level")
fib_level_50 = input.float(0.5, title="Fib 50% Level")
fib_level_618 = input.float(0.618, title="Fib 61.8% Level")
// Input to choose the level for entry signals
buy_entry_level = input.string(title="Buy Entry Level", defval="Fib 61.8%", options=["Fib 23.6%", "Fib 38.2%", "Fib 50%", "Fib 61.8%"])
sell_entry_level = input.string(title="Sell Entry Level", defval="Fib 38.2%", options=["Fib 23.6%", "Fib 38.2%", "Fib 50%", "Fib 61.8%"])
// Input for take profit and stop loss in pips
take_profit_pips = input.int(50, title="Take Profit (pips)")
stop_loss_pips = input.int(20, title="Stop Loss (pips)")
// Identify high and low points within the lookback period
highestHigh = ta.highest(high, lookback)
lowestLow = ta.lowest(low, lookback)
// Calculate Fibonacci levels based on the selected direction
var float fib_0 = na
var float fib_100 = na
var float fib_236 = na
var float fib_382 = na
var float fib_50 = na
var float fib_618 = na
if fib_direction == "Top to Bottom"
fib_0 := highestHigh
fib_100 := lowestLow
fib_236 := highestHigh - (highestHigh - lowestLow) * fib_level_236
fib_382 := highestHigh - (highestHigh - lowestLow) * fib_level_382
fib_50 := highestHigh - (highestHigh - lowestLow) * fib_level_50
fib_618 := highestHigh - (highestHigh - lowestLow) * fib_level_618
else
fib_0 := lowestLow
fib_100 := highestHigh
fib_236 := lowestLow + (highestHigh - lowestLow) * fib_level_236
fib_382 := lowestLow + (highestHigh - lowestLow) * fib_level_382
fib_50 := lowestLow + (highestHigh - lowestLow) * fib_level_50
fib_618 := lowestLow + (highestHigh - lowestLow) * fib_level_618
// Determine which level to use for buy and sell signals based on user input
var float buy_fib_level = na
var float sell_fib_level = na
if buy_entry_level == "Fib 23.6%"
buy_fib_level := fib_236
if buy_entry_level == "Fib 38.2%"
buy_fib_level := fib_382
if buy_entry_level == "Fib 50%"
buy_fib_level := fib_50
if buy_entry_level == "Fib 61.8%"
buy_fib_level := fib_618
if sell_entry_level == "Fib 23.6%"
sell_fib_level := fib_236
if sell_entry_level == "Fib 38.2%"
sell_fib_level := fib_382
if sell_entry_level == "Fib 50%"
sell_fib_level := fib_50
if sell_entry_level == "Fib 61.8%"
sell_fib_level := fib_618
// Convert pips to price units (assuming 1 pip = 0.0001 for currency pairs like EURUSD)
pip_value = syminfo.mintick * 10
take_profit = take_profit_pips * pip_value
stop_loss = stop_loss_pips * pip_value
// Trading signals
var bool longSignal = na
var bool shortSignal = na
if fib_direction == "Top to Bottom"
longSignal := ta.crossover(close, buy_fib_level) and close > buy_fib_level
shortSignal := ta.crossunder(close, sell_fib_level) and close < sell_fib_level
else
longSignal := ta.crossover(close, buy_fib_level) and close > buy_fib_level
shortSignal := ta.crossunder(close, sell_fib_level) and close < sell_fib_level
// Execute trades based on signals with take profit and stop loss
if (longSignal)
strategy.entry("Long", strategy.long, comment="BUY")
strategy.exit("Take Profit/Stop Loss", "Long", limit=close + take_profit, stop=close - stop_loss)
if (shortSignal)
strategy.entry("Short", strategy.short, comment="SELL")
strategy.exit("Take Profit/Stop Loss", "Short", limit=close - take_profit, stop=close + stop_loss)
// Plot Fibonacci levels
plot(fib_0, title="Fib 0%", color=color.blue, linewidth=1, style=plot.style_line)
plot(fib_236, title="Fib 23.6%", color=color.green, linewidth=1, style=plot.style_line)
plot(fib_382, title="Fib 38.2%", color=color.green, linewidth=1, style=plot.style_line)
plot(fib_50, title="Fib 50%", color=color.red, linewidth=1, style=plot.style_line)
plot(fib_618, title="Fib 61.8%", color=color.green, linewidth=1, style=plot.style_line)
plot(fib_100, title="Fib 100%", color=color.blue, linewidth=1, style=plot.style_line)
// Create labels for Fibonacci levels with white text
var label fibLabel0 = na
var label fibLabel236 = na
var label fibLabel382 = na
var label fibLabel50 = na
var label fibLabel618 = na
var label fibLabel100 = na
if (na(fibLabel0))
fibLabel0 := label.new(bar_index, fib_0, text="Fib 0%", color=na, textcolor=color.white, style=label.style_label_right, yloc=yloc.price)
fibLabel236 := label.new(bar_index, fib_236, text="Fib 23.6%", color=na, textcolor=color.white, style=label.style_label_right, yloc=yloc.price)
fibLabel382 := label.new(bar_index, fib_382, text="Fib 38.2%", color=na, textcolor=color.white, style=label.style_label_right, yloc=yloc.price)
fibLabel50 := label.new(bar_index, fib_50, text="Fib 50%", color=na, textcolor=color.white, style=label.style_label_right, yloc=yloc.price)
fibLabel618 := label.new(bar_index, fib_618, text="Fib 61.8%", color=na, textcolor=color.white, style=label.style_label_right, yloc=yloc.price)
fibLabel100 := label.new(bar_index, fib_100, text="Fib 100%", color=na, textcolor=color.white, style=label.style_label_right, yloc=yloc.price)
else
label.set_xy(fibLabel0, bar_index, fib_0)
label.set_xy(fibLabel236, bar_index, fib_236)
label.set_xy(fibLabel382, bar_index, fib_382)
label.set_xy(fibLabel50, bar_index, fib_50)
label.set_xy(fibLabel618, bar_index, fib_618)
label.set_xy(fibLabel100, bar_index, fib_100)
// Plot signals
plotshape(series=longSignal, location=location.belowbar, color=color.green, style=shape.labelup, title="Buy Signal", text="BUY")
plotshape(series=shortSignal, location=location.abovebar, color=color.red, style=shape.labeldown, title="Sell Signal", text="SELL")
// Plot highest and lowest points
plot(highestHigh, title="Highest High", color=color.purple, linewidth=2, offset=-lookback)
plot(lowestLow, title="Lowest Low", color=color.purple, linewidth=2, offset=-lookback)