
यह रणनीति मूल्य के ब्रेकआउट और औसत वापसी के संयोजन पर आधारित है, जो कई संकेतकों का उपयोग करके पुष्टि और छानने के लिए है, जो प्रवृत्ति के निर्णय और ट्रैकिंग को सक्षम बनाता है। यह रणनीति लघु और मध्य रेखा व्यापार के लिए उपयुक्त है, जो सख्त प्रवेश और निकास तंत्र के माध्यम से छोटे मुनाफे को लॉक करती है।
मूल्य प्रवृत्ति की दिशा निर्धारित करने के लिए HMA औसत रेखा का उपयोग करें। औसत रेखा से ऊपर की कीमतें उछाल और औसत रेखा से नीचे की कीमतें गिरावट हैं।
एसएसएल चैनल एक पुष्टिकरण सूचक के रूप में, चैनल की दिशा और मूल्य संबंध के माध्यम से प्रवृत्ति की पुष्टि करता है।
टीडीएफआई एक मात्रात्मक क्षमता के रूप में कार्य करता है, जो निर्णय लेने की क्षमता को दर्शाता है। केवल एक निश्चित स्तर तक पहुंचने के बाद ही प्रवेश प्राप्त किया जा सकता है।
RVI सूचक एक बाहर निकलने का सूचक है, जब RVI लाइन का आकार बदल जाता है, तो यह निर्धारित करता है कि प्रवृत्ति समाप्त हो गई है और स्थिति से बाहर निकलती है।
एटीआर सूचक स्टॉप लॉस और स्टॉप बैंड की गणना करता है।
प्रवेश की शर्तेंः कीमतों ने बेंचमार्क रेखा को पार कर लिया, एसएसएल मार्ग की दिशा कीमतों के अनुरूप है, टीडीएफआई थ्रेशोल्ड तक पहुंच गया है।
बाहर निकलने की शर्तेंः आरवीआई सूचकांक रेखा आकृति में परिवर्तन, या कीमतें वापस बेसिक लाइन और एसएसएल चैनल को तोड़ देती हैं।
कई सूचकांकों के संयोजन का उपयोग करके, यह फ़िल्टर करने के लिए प्रभावी है।
सख्त प्रविष्टि शर्तें और स्टॉप लॉस एक्जिट, एक बार के स्टॉप लॉस को नियंत्रित किया जा सकता है
कीमतों के रुझानों का लाभ उठाएं और अतिरिक्त लाभ प्राप्त करें।
सूचक पैरामीटर अनुकूलित करने के लिए जगह है, विभिन्न उत्पादों और चक्रों के लिए समायोजित किया जा सकता है।
हालांकि, यह स्पष्ट नहीं है कि क्या यह ट्रेंड बदल रहा है, लेकिन यह एक जोखिम है कि ओवरडोज के कारण यह बढ़ेगा या घट जाएगा।
इस प्रकार, यह कम समय में संचालित होता है और अत्यधिक लेनदेन का जोखिम होता है।
स्टॉपलॉस की सेटिंग का एक व्यक्तिपरक प्रभाव है, जो बहुत ढीला या बहुत तंग हो सकता है।
अनुचित पैरामीटर सेट करने से लेन-देन की कमी या कमी हो सकती है।
प्रवृत्ति को निर्धारित करने के लिए संकेतकों को जोड़ना और प्रवृत्ति की दिशा को निर्धारित करने की सटीकता सुनिश्चित करना।
ओवरवॉल्ट को कम करने के लिए रिवर्स सिग्नल इंडिकेटर जोड़ा गया।
एटीआर गतिशीलता को एटीआर ट्रेलिंग स्टॉप में बदलने पर विचार करें, जिससे स्टॉप लॉस अधिक गतिशील हो।
विभिन्न समरेखा प्रणालियों का परीक्षण करें और पैरामीटर अनुकूलन दिशाओं की तलाश करें।
संकेतक पैरामीटर का अनुकूलन करें, विशिष्ट व्यापार किस्मों के लिए पैरामीटर को समायोजित करें।
इस रणनीति के माध्यम से कई संकेतकों की पुष्टि की है, व्यापार संकेतों को सटीक बनाने के लिए. सख्त रोक-लगाव तंत्र एक भी नुकसान को नियंत्रित करती है. यह रणनीति तकनीकी विश्लेषण संचालन से परिचित लोगों के लिए उपयुक्त है, पैरामीटर को समायोजित करके विभिन्न बाजार चक्रों के लिए अनुकूल है. कुल मिलाकर, इस रणनीति के सकारात्मक प्रभाव और लाभ है, लेकिन प्रवृत्ति के गलत निर्णय और अत्यधिक व्यापार के जोखिम को रोकने के लिए ध्यान देने की आवश्यकता है.
/*backtest
start: 2022-11-06 00:00:00
end: 2023-11-12 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=3
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//Designed per No Nonsense Forex VP rules
//Made to be as modular as possible, so we can swap the indicators in and out.
//Originated from causecelebre
//Tried to put in as much VP rules as possible
///////////////////////////////////////////////////
//Rules Implemented:
///////////////////////////////////////////////////
// - SL 1.5 x ATR
// - TP 1 x ATR
//
// - Entry conditions
//// - Entry within 1 candles of baseline + 1 x confirmation + volume
//// - Entry only if baseline is < 1 x ATR
// - Exit conditions
//// - Exit on exit indicator or when baseline or confirmation flip
///////////////////////////////////////////////////
//Trades entries
///////////////////////////////////////////////////
// - First entry L1 or S1 with standard SL and TP
// - Second entry L2 or S2 with standard SL and exit upon the exit conditions
///////////////////////////////////////////////////
//Included Indicators and settings
///////////////////////////////////////////////////
// - Baseline = HMA 20
// - Confirmtion = SSL 10
// - Volume = TDFI 4
// - Exit = RVI 4
///////////////////////////////////////////////////
//Credits
// Strategy causecelebre https://www.tradingview.com/u/causecelebre/
// TDFI causecelebre https://www.tradingview.com/u/causecelebre/
// SSL Channel ErwinBeckers https://www.tradingview.com/u/ErwinBeckers/
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
strategy(title="NNFX Strategy | jh", overlay = true )
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// **** Set the main stuff ****
///////////////////////////////////////////////////
//Price
price = close
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// ATR stuff
///////////////////////////////////////////////////
atrLength = input(14, "ATR Length")
slMultiplier = input(1.5, "SL")
tpMultiplier = input(1, "TP")
atr = atr(atrLength)
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// **** Baseline ****
///////////////////////////////////////////////////
///////////////////////////////////////////////////
//HMA 20
///////////////////////////////////////////////////
hmaslowlength = input(20, minval=1)
src = input(close, title="Source")
slowhullma = wma(2*wma(src, hmaslowlength/2)-wma(src, hmaslowlength), round(sqrt(hmaslowlength)))
plot(slowhullma, title = "baseline", color = yellow, linewidth=2, transp=0)
///////////////////////////////////////////////////
// Base Signals
///////////////////////////////////////////////////
///////////////////////////////////////////////////
baseline = slowhullma
//Signals based on crossover
//baseShort = crossover(baseLine, price)
//baseLong = crossover(price, baseLine)
//Signals based on signal position
b_Short = baseline > price ? 1 : 0
l_Long = baseline < price ? 1 : 0
baseShort = b_Short
baseLong = l_Long
///////////////////////////////////////////////////
//ATR Check
///////////////////////////////////////////////////
distBasefromPrice = abs(baseline - price)
atrCheck = distBasefromPrice <= atr ? 1 : 0
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// **** Confirmation ****
///////////////////////////////////////////////////
///////////////////////////////////////////////////
//SSL Channel
///////////////////////////////////////////////////
sslLen=input(title="SSL Period", defval=10)
smaHigh=sma(high, sslLen)
smaLow=sma(low, sslLen)
Hlv = na
Hlv := close > smaHigh ? 1 : close < smaLow ? -1 : Hlv[1]
sslDown = Hlv < 0 ? smaHigh: smaLow
sslUp = Hlv < 0 ? smaLow : smaHigh
///////////////////////////////////////////////////
//Confirm Signals
///////////////////////////////////////////////////
c_Up = sslUp
c_Down = sslDown
//Signals based on crossover
c_Long = crossover(c_Up, c_Down)
c_Short = crossover(c_Down, c_Up)
confirmLong = c_Long
confirmShort = c_Short
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// **** Volume Indicator Start ****
///////////////////////////////////////////////////
///////////////////////////////////////////////////
//TDFI
///////////////////////////////////////////////////
lookback = input(4, title = "TDFI Lookback")
filterHigh = input(0.05, title = "Filter High")
filterLow = input(-0.05, title = "Filter Low")
mma = ema(price * 1000, lookback)
smma = ema(mma, lookback)
impetmma = mma - mma[1]
impetsmma= smma - smma[1]
divma = abs(mma - smma)
averimpet = (impetmma + impetsmma) / 2
number = averimpet
pow = 3
result = na
for i = 1 to pow - 1
if i == 1
result := number
result := result * number
tdf = divma * result
ntdf = tdf / highest(abs(tdf), lookback * 3)
///////////////////////////////////////////////////
//Volume Signals
///////////////////////////////////////////////////
v_Long = ntdf > filterHigh ? 1 : 0
v_Short = filterLow > ntdf ? 1 : 0
volumeLong = v_Long
volumeShort = v_Short
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// **** Exit Indicator ****
///////////////////////////////////////////////////
///////////////////////////////////////////////////
//RVI 4
///////////////////////////////////////////////////
rgvlen = input(4, title="RVI Length", minval=1)
rvi = sum(swma(close-open), rgvlen)/sum(swma(high-low),rgvlen)
sig = swma(rvi)
///////////////////////////////////////////////////
//Exit Signals
///////////////////////////////////////////////////
e_Short = crossover(rvi, sig)
e_Long = crossover(sig, rvi)
exitOutofShort = e_Short
exitOutofLong = e_Long
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// **************************** Logic to handle NNFX rules ****************************
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//Checking for base and confirmation indication with 1 candle difference
baseandConfirmLong = ((baseLong[0] and confirmLong[0]) or (baseLong[1] and confirmLong[0]) or (baseLong[1] and confirmLong[1]) or (baseLong[0] and confirmLong[1])) ? 1 : 0
baseandConfirmShort = ((baseShort[0] and confirmShort[0]) or (baseShort[1] and confirmShort[0]) or (baseShort[1] and confirmShort[1]) or (baseShort[0] and confirmShort[1])) ? 1 : 0
//Combining with volume with 1 candle difference
enterLong = ((baseandConfirmLong[0] and volumeLong[0]) or (baseandConfirmLong[1] and volumeLong[0]) or (baseandConfirmLong[1] and volumeLong[1]) or (baseandConfirmLong[0] and volumeLong[1])) ? 1 : 0
enterShort = ((baseandConfirmShort[0] and volumeShort[0]) or (baseandConfirmShort[1] and volumeShort[0]) or (baseandConfirmShort[1] and volumeShort[1]) or (baseandConfirmShort[0] and volumeShort[1])) ? 1 : 0
//Exit on base or confirmation flip over
baseandConfirmFliptoShort = ((baseShort[0] or confirmShort[0]) or (baseShort[1] or confirmShort[0]) or (baseShort[1] or confirmShort[1]) or (baseShort[0] or confirmShort[1])) ? 1 : 0
baseandConfirmFliptoLong = ((baseLong[0] or confirmLong[0]) or (baseLong[1] or confirmLong[0]) or (baseLong[1] or confirmLong[1]) or (baseLong[0] or confirmLong[1])) ? 1 : 0
//Exit on base and confirmation flip or exit indicator
exitLong = exitOutofLong or baseandConfirmFliptoShort ? 1 : 0
exitShort = exitOutofShort or baseandConfirmFliptoLong ? 1 : 0
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//Entries and Exits
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
if (year>2009)
//Long entries with standard 1.5 ATR for SL, 1 ATR for TP
long_sl = price - atr * slMultiplier
long_tp = price + atr * tpMultiplier
strategy.entry("L1", strategy.long, when = enterLong and atrCheck)
strategy.exit("L1 SL Exit", "L1", stop = long_sl, limit = long_tp)
strategy.close("L1", when = exitLong)
//Long entries with no TP
strategy.entry("L2", strategy.long, when = enterLong and atrCheck)
strategy.exit("L2 SL Exit", "L2", stop = long_sl)
strategy.close("L2", when = exitLong)
//Short entries with standard 1.5 ATR for SL, 1 ATR for TP
short_sl = price + atr * slMultiplier
short_tp = price - atr * tpMultiplier
strategy.entry("S1", strategy.short, when = enterShort and atrCheck)
strategy.exit("S1 SL Exit", "Short1", stop = short_sl, limit = short_tp)
strategy.close("S1", when = exitShort)
//Short entries with no TP
strategy.entry("S2", strategy.short, when = enterShort and atrCheck)
strategy.exit("S2 Exit", stop = short_sl)
strategy.close("S2", when = exitShort)
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//End
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////