
यह रणनीति एक मात्रात्मक ट्रेडिंग प्रणाली है जो शून्य-विलंबता चलती औसत और प्रवृत्ति की ताकत के स्कोर पर आधारित है। यह बाजार की प्रवृत्ति की पहचान करने के लिए अस्थिरता के चैनल और प्रवृत्ति की ताकत के स्कोर के संयोजन के साथ पारंपरिक चलती औसत की विलंबता को समाप्त करके कीमतों में अल्पकालिक उतार-चढ़ाव के अवसरों को पकड़ता है। यह रणनीति एक द्वि-दिशात्मक ट्रेडिंग मोड का उपयोग करती है, जो बढ़ती प्रवृत्ति में अधिक है, और गिरावट में शून्य है, और जोखिम को नियंत्रित करने के लिए स्टॉप-लॉस सेट करती है।
इस रणनीति का मुख्य उद्देश्य पारंपरिक चलती औसत के अंतराल को शून्य-विलंब चलती औसत के माध्यम से समाप्त करना है। इसे लागू करने का तरीका यह है कि पहले वर्तमान मूल्य और अंतराल मूल्य के बीच अंतर की गणना की जाती है, फिर उस अंतर को वर्तमान मूल्य के साथ जोड़ा जाता है, और अंत में परिणामों के लिए एक चलती औसत की गणना की जाती है। साथ ही, रणनीति ने एक प्रवृत्ति ताकत स्कोरिंग प्रणाली पेश की है, जो विभिन्न समय अवधि की कीमतों के उतार-चढ़ाव की तुलना करके प्रवृत्ति की ताकत को मापता है। इसके अलावा, रणनीति ने एटीआर-आधारित गतिशील अस्थिरता चैनल को व्यापार संकेतों को तोड़ने के लिए स्थापित किया है।
इस रणनीति के लिए एक अभिनव शून्य विलंब गणना विधि और प्रवृत्ति ताकत स्कोरिंग प्रणाली के माध्यम से अच्छी तरह से पारंपरिक प्रवृत्ति ट्रैकिंग रणनीति में अंतराल को हल किया है. साथ ही, गतिशील अस्थिरता चैनल और बेहतर जोखिम नियंत्रण तंत्र की शुरूआत के माध्यम से रणनीति की स्थिरता और विश्वसनीयता को बढ़ाया है. हालांकि रणनीति पैरामीटर अनुकूलन और बाजार अनुकूलता के मामले में सुधार के लिए जगह है, लेकिन समग्र डिजाइन विचार स्पष्ट है और बेहतर वास्तविक मूल्य अनुप्रयोग है.
/*backtest
start: 2024-11-14 00:00:00
end: 2025-02-19 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Binance","currency":"DOGE_USDT"}]
*/
// This Pine Script™ code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © josephdelvecchio
//@version=6
strategy("Zero Lag Trend Strategy", overlay=true)
// -- Input Parameters --
timeframe = input.timeframe("10", "Timeframe")
zeroLagMovAvg = input.string("ema", "Zero Lag Moving Average", options=["ema", "sma"])
length = input.int(50, "Lookback Period")
volatility_mult = input.float(1.5, "Volatility Multiplier")
loop_start = input.int(1, "Loop Start")
loop_end = input.int(50, "Loop End")
threshold_up = input.int(5, "Threshold Up")
threshold_down = input.int(-5, "Threshold Down")
signalpct = input.float(8, "Signal Percentage")
stoppct = input.float(0, "Stop Percentage")
// -- Helper Variables --
nATR = ta.atr(length)
lag = math.floor((length - 1) / 2)
zl_basis = zeroLagMovAvg == "ema" ? ta.ema(2 * close - close[lag], length) : ta.sma(2 * close - close[lag], length)
volatility = ta.highest(nATR, length * 3) * volatility_mult
// -- Trend Strength Scoring Function --
forloop_analysis(basis_price, loop_start, loop_end) =>
int sum = 0 // Use 'sum' as you did originally, for the +/- logic
for i = loop_start to loop_end
if basis_price > basis_price[i]
sum += 1
else if basis_price < basis_price[i] // Explicitly check for less than
sum -= 1
// If they are equal, do nothing (sum remains unchanged)
sum
score = forloop_analysis(zl_basis, loop_start, loop_end)
// -- Signal Generation --
long_signal = score > threshold_up and close > zl_basis + volatility
short_signal = score < threshold_down and close < zl_basis - volatility
// -- Trend Detection (Ensure One Trade Until Reversal) --
var int trend = na
trend := long_signal ? 1 : short_signal ? -1 : trend[1]
trend_changed = trend != trend[1]
// -- Stop-Loss & Take-Profit --
stop_loss = close * (1 - stoppct / 100)
take_profit = close * (1 + signalpct / 100)
// -- Strategy Orders (Enter Only When Trend Changes) --
if long_signal
strategy.entry("Long", strategy.long)
else if short_signal
strategy.entry("Short", strategy.short)
// -- Strategy Exits --
strategy.exit("Exit Long", from_entry="Long", stop=stop_loss, limit=take_profit)
strategy.exit("Exit Short", from_entry="Short", stop=take_profit, limit=stop_loss)
// -- Visualization --
p_basis = zl_basis
plot(p_basis, title="Zero Lag Line", color=color.blue, linewidth=2)
// -- Buy/Sell Arrows --
plotshape(series=trend_changed and trend == 1, location=location.belowbar, color=color.green, style=shape.triangleup, size=size.large, title="Buy Signal")
plotshape(series=trend_changed and trend == -1, location=location.abovebar, color=color.red, style=shape.triangledown, size=size.large, title="Sell Signal")