
इस रणनीति का उद्देश्य यह परीक्षण करना है कि क्या विभिन्न इनपुट चर जैसे कि के-लाइन रंग, क्रॉसिंग मात्रा और यादृच्छिक तरीके से कीमत में बदलाव की भविष्यवाणी करने के लिए सिग्नल तरंगों का उपयोग किया जा सकता है। रणनीति इन चरों को सिग्नल तरंगों के रूप में बदलती है, जब वेव पीक या वेव घाटी एक सेट संख्या तक पहुंच जाती है, तो खरीद या बेचने का निर्णय लिया जाता है।
रणनीति को तीन भागों में विभाजित किया गया है, पहला भाग K लाइनों के रंग में परिवर्तन का पता लगाता है। जब कई समान रंग की K लाइनों के बाद, अलग-अलग रंग दिखाई देते हैं, तो ध्रुवीय तरंगों को बदल दिया जाता है। दूसरा भाग यह पता लगाने के लिए है कि क्या यातायात औसत से अधिक या कम है, और औसत को तोड़ने पर तरंगों को बदल दिया जाता है। तीसरा भाग एक यादृच्छिक विधि का उपयोग करके सिक्कों को मोड़ने का अनुकरण करता है, और यादृच्छिक परिणाम अलग-अलग होते हैं। ये तीन तरंगें एक सेट संख्या तक जमा होती हैं, और व्यापार निर्णय लेते हैं।
कोड तीन तरंगों की वर्तमान दिशा, वेव पीक और शीर्ष K लाइन की स्थिति को ट्रैक करके तरंगों के संचालन को नियंत्रित करता है। जब वेव पीक पैरामीटर सेट तक पहुंचता है, तो वेव दिशा को बदल देता है। इस चक्र के माध्यम से, वेव सिग्नल ऑपरेशन का अनुकरण करते हैं।
यह सिग्नल तरंग सिद्धांत काफी समझ में आता है, और सिमुलेटेड तरंगों का वास्तविक बाजार के साथ कुछ संबंध है। लेकिन इस रणनीति के परीक्षण से पता चलता है कि यह वास्तव में यादृच्छिक परिणाम है। कौन सा चर संयोजन तरंगों की तरह दिखता है, व्यापार के परिणामों में सुधार नहीं करता है।
इसलिए इस रणनीति का एक फायदा यह है कि यह गलत धारणा को खारिज करता है कि कद्दू बाजार कद्दू की भविष्यवाणी कर सकते हैं। बाजार में चर वास्तव में कीमतों को प्रभावित करते हैं, लेकिन अप्रत्याशित, यादृच्छिक निर्णयों के साथ भी समान परिणाम मिल सकते हैं।
इस रणनीति का सबसे बड़ा जोखिम यह है कि यादृच्छिक व्यापार में लाभ और हानि का निर्धारण करना मुश्किल है। विभिन्न मापदंडों के तहत परिणाम की भविष्यवाणी करना मुश्किल है, यह निर्धारित करना संभव नहीं है कि यह लाभदायक है या नहीं।
इसके अलावा, सिग्नल तरंगों की भविष्यवाणी का सिद्धांत स्वयं ही गलत है। बाजार में परिवर्तन बहुत जटिल है और इसे सरल आवर्ती सिमुलेशन के साथ लागू करना असंभव है। इसलिए यह रणनीति वास्तविक समय में ट्रेडिंग के लिए लागू नहीं की जा सकती है।
जोखिम को कम करने के लिए, या तो एक पैरामीटर रेंज निर्धारित करने के लिए यादृच्छिक परिणामों का आगे विश्लेषण करने की आवश्यकता है; या व्यापार संकेतों को सत्यापित करने के लिए अन्य विश्लेषण विधियों के साथ संयोजन में।
इस रणनीति को निम्नलिखित दिशाओं में अनुकूलित किया जा सकता हैः
यह रणनीति विभिन्न सिग्नल तरंगों का परीक्षण करके बाजार की अप्रत्याशितता की प्रकृति को बताती है। साथ ही साथ यह गलत सिद्धांतों को भी खारिज करता है जो लहरों के चक्रों का उपयोग करके भविष्यवाणी करते हैं।
अगले चरण में, रणनीति की स्थलीय उपलब्धता को बढ़ाया जा सकता है जैसे कि चर जोड़ना, लहरों को जोड़ना, स्टॉप लॉस और ऑप्टिमाइज़ेशन पैरामीटर सेट करना। लेकिन यह समझना महत्वपूर्ण है कि बाजार में परिवर्तन जटिल और परिवर्तनशील है और इसकी भविष्यवाणी करना आसान नहीं है। हम जो कर रहे हैं वह आकस्मिक जोखिम को कम करना है, न कि बाजार की भविष्यवाणी करना।
/*backtest
start: 2022-11-14 00:00:00
end: 2023-11-20 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © Gentleman-Goat
//@version=5
strategy("Sine Wave Theory",overlay=false, precision = 2, initial_capital = 1000,shorttitle = "SINE_W_T")
var bar_change_wave_direction = input.int(defval=1,title="Starting Wave Direction",group="Bar Change")
bar_change_sine_wave_number = input.int(defval=28,title="Sine Wave #",group="Bar Change")
bar_change_sine_wave_res = input.timeframe(defval="D",title="Resolution",group="Bar Change")
bar_change_trade = input.bool(defval=true,title="Trade",group="Bar Change")
var volume_wave_direction = input.int(defval=1,title="Starting Wave Direction",group="Volume")
avg_volume_length = input.int(7,title="Lookback Length",group="Volume")
volume_sine_wave_number = input.int(defval=28,title="Sine Wave #",group="Volume")
volume_sine_wave_res = input.timeframe(defval="D",title="Resolution",group="Volume")
volume_trade = input.bool(defval=false,title="Trade",group="Volume")
var coin_flip_wave_direction = input.int(defval=1,title="Starting Wave Direction",group="Coin Flip")
coin_flip_sine_wave_number = input.int(defval=28,title="Sine Wave #",group="Coin Flip")
coin_flip_seed = input.int(defval=1,title="Seed #",group="Coin Flip")
coin_flip_trade = input.bool(defval=false,title="Trade",group="Coin Flip")
avg_volume = ta.sma(volume,avg_volume_length)
//Green or Red Candle
bar_color = close>open ? color.green : color.red
bar_color_time_adj = request.security(syminfo.tickerid, bar_change_sine_wave_res, bar_color)
//Above or Below Average
volume_state = (volume>avg_volume) ? color.blue : color.purple
volume_state_time_adj = request.security(syminfo.tickerid, volume_sine_wave_res, volume_state)
//Coinflip
coin_flip = math.random(0,100,coin_flip_seed)>=50 ? color.teal : color.yellow
var bar_change_wave_count = 0
var volume_wave_count = 0
var coin_flip_wave_count = 0
//Wave Counters
if(volume_state_time_adj[1] != volume_state_time_adj)
volume_wave_count := volume_wave_count + volume_wave_direction
if(bar_color_time_adj[1] != bar_color_time_adj)
bar_change_wave_count := bar_change_wave_count + bar_change_wave_direction
if(coin_flip[1] != coin_flip)
coin_flip_wave_count := coin_flip_wave_count + coin_flip_wave_direction
//Direction changers
if(math.abs(bar_change_wave_count) == bar_change_sine_wave_number and bar_color_time_adj[1] != bar_color_time_adj)
bar_change_wave_direction := bar_change_wave_direction * -1
if(math.abs(volume_wave_count) == volume_sine_wave_number and volume_state_time_adj[1] != volume_state_time_adj)
volume_wave_direction := volume_wave_direction * -1
if(math.abs(coin_flip_wave_count) == coin_flip_sine_wave_number and coin_flip[1] != coin_flip)
coin_flip_wave_direction := coin_flip_wave_direction * -1
//Entry positions
if(bar_change_wave_count==bar_change_sine_wave_number and bar_change_trade==true)
strategy.entry(id="short",direction=strategy.short)
if(bar_change_wave_count==bar_change_sine_wave_number*-1 and bar_change_trade==true)
strategy.entry(id="long",direction=strategy.long)
if(volume_wave_count==volume_sine_wave_number and volume_trade==true)
strategy.entry(id="short-volume",direction=strategy.short)
if(volume_wave_count==volume_sine_wave_number*-1 and volume_trade==true)
strategy.entry(id="long-volume",direction=strategy.long)
if(coin_flip_wave_count==coin_flip_sine_wave_number and coin_flip_trade==true)
strategy.entry(id="short-coinflip",direction=strategy.short)
if(coin_flip_wave_count==coin_flip_sine_wave_number*-1 and coin_flip_trade==true)
strategy.entry(id="long-coinflip",direction=strategy.long)
hline(0, title='Center', color=color.white, linestyle=hline.style_dashed, linewidth=1)
plot(bar_change_wave_count,title="Bar Change", color=bar_color, linewidth=2)
plot(volume_wave_count,title="Volume Average Change", color=volume_state, linewidth=2)
plot(coin_flip_wave_count,title="Coin Flip Change", color=coin_flip, linewidth=2)