এই কৌশলটি ট্রেডিং সিস্টেম অনুসরণ করে একটি প্রবণতা ডিজাইন করার জন্য কাউফম্যান অ্যাডাপ্টিভ মুভিং এভারেজ (কামা) সূচক ব্যবহার করে। এটি শক্ত ঝুঁকি নিয়ন্ত্রণের ক্ষমতা সহ স্টপ লস প্রক্রিয়া হিসাবে প্যারাবোলিক এসএআর (পিএসএআর) এবং গড় সত্য পরিসীমা ট্রেলিং স্টপকেও একীভূত করে।
KAMA সূচকটির দৈর্ঘ্য সাম্প্রতিক বাজারের অস্থিরতার উপর ভিত্তি করে গতিশীলভাবে সামঞ্জস্য করা হয়। যখন দামের পরিবর্তন সাম্প্রতিক গোলমালের চেয়ে বেশি হয়, তখন ইএমএ উইন্ডোটি ছোট হয়ে যায়। যখন দামের পরিবর্তন সাম্প্রতিক গোলমালের চেয়ে ছোট হয়, তখন ইএমএ উইন্ডোটি দীর্ঘ হয়ে যায়। এটি KAMA কে দ্রুত ট্রেন্ডগুলি ট্র্যাক করতে দেয় যখন অশান্ত বাজারের সময় গোলমাল ফিল্টার করে।
সিস্টেমটি মূলত দ্রুততম KAMA (KAMA 1) এর উপর ভিত্তি করে প্রবণতা দিক বিচার করে। এটি দীর্ঘ হয় যখন KAMA 1 উপরে নির্দেশ করে এবং KAMA 1 নীচে নির্দেশ করে যখন এটি সংক্ষিপ্ত হয়। মিথ্যা বিরতি ফিল্টার করতে, একটি KAMA ফিল্টার সেট করা হয়। ট্রেডিং সংকেতগুলি কেবল তখনই উত্পন্ন হয় যখন KAMA 1 এর পরিবর্তন সাম্প্রতিক ওঠানামাগুলির এক স্ট্যান্ডার্ড বিচ্যুতি অতিক্রম করে।
স্টপ লসের জন্য, সিস্টেমটি তিনটি ঐচ্ছিক স্টপ লস পদ্ধতি সরবরাহ করেঃ কামা বিপরীত, পিএসএআর বিপরীত এবং এটিআর ট্রেলিং স্টপ। বিনিয়োগকারীরা একটি বা ব্যবহারের জন্য একটি সমন্বয় চয়ন করতে পারেন।
KAMA ইন্ডিকেটরের অনন্য নকশা সিস্টেমকে দ্রুত উদীয়মান প্রবণতা ধরা, অস্থির বাজারের সময় ট্রেডিং বন্ধ, কার্যকরভাবে ট্রেডিং ফ্রিকোয়েন্সি নিয়ন্ত্রণ, এবং অপ্রয়োজনীয় স্লিপ এবং কমিশন খরচ কমাতে সক্ষম করে।
এই ব্যবস্থায় একাধিক স্টপ লস মেশিন রয়েছে। বিনিয়োগকারীরা তাদের ব্যক্তিগত ঝুঁকি পছন্দ অনুযায়ী উপযুক্ত স্টপ লস স্কিমটি বেছে নিতে পারেন যাতে একক ক্ষতি কার্যকরভাবে নিয়ন্ত্রণ করা যায়।
সিস্টেমটি সম্পূর্ণরূপে সূচক এবং স্টপ লস লাইনে ভিত্তি করে তৈরি, যা লেনদেনের পরিবর্তনের কারণে সাধারণ ভুল প্রবেশের সমস্যা এড়ায়।
একাধিক পরামিতি সেটিং এবং শর্ত সমন্বয় সিস্টেম কাস্টমাইজেশনের জন্য মহান স্থান প্রদান করে। ব্যবহারকারীরা বিভিন্ন পণ্য এবং ফ্রিকোয়েন্সি অনুযায়ী অপ্টিমাইজ করতে পারেন।
এই সিস্টেমটি সিস্টেমিক ঝুঁকি বিবেচনা করে না এবং চরম বাজারের পরিস্থিতিতে ক্ষয়ক্ষতি কার্যকরভাবে নিয়ন্ত্রণ করতে পারে না।
সিস্টেম PARAMETERS বিভিন্ন পণ্য এবং ফ্রিকোয়েন্সি অনুযায়ী সামঞ্জস্য করা প্রয়োজন হতে পারে, অন্যথায় এটি অত্যধিক আক্রমণাত্মক বা অত্যধিক সংরক্ষণশীল ফলাফল প্রদান করবে।
স্টপ লসের জন্য যদি কেবলমাত্র KAMA সূচকের উপর নির্ভর করা হয়, তবে অস্থির বাজারের সময় উইপসায় ধরা পড়া সহজ। এটি সমাধানের জন্য পিএসএআর বা এটিআর ট্রেলিং স্টপের সাথে একত্রিত করা দরকার।
অস্থির এবং প্রবণতা রূপান্তর পর্যায়ে ভুল সংকেত তৈরি করা এড়াতে ADX বা নিহিত অস্থিরতার মতো প্রবণতা ফিল্টারিং সূচক যুক্ত করুন।
স্থিতিশীলতা উন্নত করার জন্য পৃথক পণ্য এবং স্থির ফ্রিকোয়েন্সিগুলির জন্য প্যারামিটারগুলি অনুকূলিতকরণ এবং ব্যাকটেস্ট করুন। অপ্টিমাইজেশান মাত্রাগুলিতে কামা প্যারামিটার সংমিশ্রণ, স্টপ লস প্যারামিটার ইত্যাদি অন্তর্ভুক্ত রয়েছে
প্যারামিটার অপ্টিমাইজেশনের পরিবর্তে মেশিন লার্নিং মডেল চেষ্টা করুন। প্রবেশ এবং প্রস্থান সময় এবং স্টপ লস বিচার করতে প্রচুর historicalতিহাসিক ডেটা সহ নিউরাল নেটওয়ার্ক বা সিদ্ধান্ত গাছের মডেলগুলি প্রশিক্ষণ দিন।
ক্রিপ্টোকারেন্সির মতো অন্যান্য পণ্যগুলিতে কৌশলটি স্থানান্তর করার চেষ্টা করুন। এটির জন্য প্যারামিটারগুলি সামঞ্জস্য করা বা অন্যান্য সহায়ক সূচক যুক্ত করা প্রয়োজন হতে পারে।
এই কৌশলটি প্রবণতা বিচার এবং কার্যকরভাবে প্রবণতা দিক এবং নিয়ন্ত্রণ ঝুঁকি ট্র্যাক করার জন্য একাধিক স্টপ লস পদ্ধতির জন্য KAMA একীভূত করে। KAMA সূচক অনন্যতা কৌশল দ্রুত উদীয়মান প্রবণতা দিক নির্ধারণ এবং মিথ্যা ব্রেকআউট সমস্যা এড়াতে পারবেন। কাস্টমাইজযোগ্য এবং অপ্টিমাইজযোগ্য পরামিতি ব্যবহারকারীদের ব্যক্তিগতকৃত সমন্বয় জন্য মহান স্থান প্রদান করে। প্যারামিটার অপ্টিমাইজ এবং পৃথক পণ্য এবং ফ্রিকোয়েন্সি জন্য মেশিন লার্নিং মডেল একীভূত করে, কৌশল কর্মক্ষমতা আরও উন্নত করা যেতে পারে।
/*backtest start: 2023-12-01 00:00:00 end: 2023-12-31 23:59:59 period: 1h basePeriod: 15m 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/ // © BenHampson // @version=4 // Credit to: // - ChuckBanger for much of the KAMA code // - cheatcountry for the KAMA Filter code // - millerrh for much of the ATR Stop code // - racer8 for much of the Position Sizing code // I have combined aspects of their work and built upon it to form a strategy I like. // The KAMA, with its filter, is used for entry. // An ATR trailing stop loss, PSAR, and the KAMA can all optionally be used as exits, or you can use a combination of the three. strategy(title="KAMA Strategy - Kaufman's Adaptive Moving Average", shorttitle="KAMA Strategy", overlay=true) src = input(title="Source", type=input.source, defval=close) // Exits KAMA1SL = input(title = 'KAMA 1 Stop Loss', type = input.bool, defval = true) ATRTSL = input(title = 'ATR Trailing Stop Loss', type = input.bool, defval = false) PSARSL = input(title = 'PSAR Stop Loss', type = input.bool, defval = false) // KAMA 1 (Fastest) length1 = input(title="KAMA 1: Length", type=input.integer, defval=14) fastLength1 = input(title="KAMA 1: Fast KAMA Length", type=input.integer, defval=2) slowLength1 = input(title="KAMA 1: Slow KAMA Length", type=input.integer, defval=20) length2 = input(title="KAMA 2: Length 2", type=input.integer, defval=15) fastLength2 = input(title="KAMA 2: Fast KAMA Length", type=input.integer, defval=3) slowLength2 = input(title="KAMA 2: Slow KAMA Length", type=input.integer, defval=22) length3 = input(title="KAMA 3: Length 3", type=input.integer, defval=16) fastLength3 = input(title="KAMA 3: Fast KAMA Length", type=input.integer, defval=4) slowLength3 = input(title="KAMA 3: Slow KAMA Length", type=input.integer, defval=24) length4 = input(title="KAMA 4: Length", type=input.integer, defval=17) fastLength4 = input(title="KAMA 4: Fast KAMA Length", type=input.integer, defval=5) slowLength4 = input(title="KAMA 4: Slow KAMA Length", type=input.integer, defval=26) // KAMA 5 (Medium) length5 = input(title="KAMA 5: Length", type=input.integer, defval=18) fastLength5 = input(title="KAMA 5: Fast KAMA Length", type=input.integer, defval=6) slowLength5 = input(title="KAMA 5: Slow KAMA Length", type=input.integer, defval=28) length6 = input(title="KAMA 6: Length", type=input.integer, defval=19) fastLength6 = input(title="KAMA 6: Fast KAMA Length", type=input.integer, defval=7) slowLength6 = input(title="KAMA 6: Slow KAMA Length", type=input.integer, defval=30) length7 = input(title="KAMA 7: Length", type=input.integer, defval=20) fastLength7 = input(title="KAMA 7: Fast KAMA Length", type=input.integer, defval=8) slowLength7 = input(title="KAMA 7: Slow KAMA Length", type=input.integer, defval=32) // KAMA 8 (Slowest) length8 = input(title="KAMA 8: Length", type=input.integer, defval=21) fastLength8 = input(title="KAMA 8: Fast KAMA Length", type=input.integer, defval=9) slowLength8 = input(title="KAMA 8: Slow KAMA Length", type=input.integer, defval=34) // Kaufman's Adaptive Moving Average getKAMA(src, length1, fastLength1, slowLength1) => mom = abs(change(src, length1)) volatility = sum(abs(change(src)), length1) // Efficiency Ratio er = volatility != 0 ? mom / volatility : 0 fastAlpha = 2 / (fastLength1 + 1) slowAlpha = 2 / (slowLength1 + 1) // KAMA Alpha sc = pow((er * (fastAlpha - slowAlpha)) + slowAlpha, 2) kama = 0.0 kama := sc * src + (1 - sc) * nz(kama[1]) kama kama1 = getKAMA(src, length1, fastLength1, slowLength1) kama2 = getKAMA(src, length2, fastLength2, slowLength2) kama3 = getKAMA(src, length3, fastLength3, slowLength3) kama4 = getKAMA(src, length4, fastLength4, slowLength4) kama5 = getKAMA(src, length5, fastLength5, slowLength5) kama6 = getKAMA(src, length6, fastLength6, slowLength6) kama7 = getKAMA(src, length7, fastLength7, slowLength7) kama8 = getKAMA(src, length8, fastLength8, slowLength8) //If the kama1 has increased... kama1delta = kama1[0] - kama1[1] kama3delta = kama3[0] - kama3[1] kama8delta = kama8[0] - kama8[1] // KAMA Plots plot(kama1, title="KAMA 1", color=#e91e63, display=display.all, linewidth=2) plot(kama2, title="KAMA 2", color=color.red, display=display.all) plot(kama3, title="KAMA 3", color=color.red, display=display.all) plot(kama4, title="KAMA 4", color=color.orange, display=display.all) plot(kama5, title="KAMA 5", color=color.orange, display=display.all) plot(kama6, title="KAMA 6", color=color.yellow, display=display.all) plot(kama7, title="KAMA 7", color=color.yellow, display=display.all) plot(kama8, title="KAMA 8", color=color.white, display=display.all) //========================================= KAMA FILTER =========================================== // Copyright (c) 2019-present, Franklin Moormann (cheatcountry) // Moving Average Adaptive Filter [CC] script may be freely distributed under the MIT license. entryFilter = input(title="KAMA Entry Filter", type=input.float, defval=1, minval=0.01) exitFilter = input(title="KAMA Exit Filter", type=input.float, defval=0.5, minval=0.01) entryMAAF = entryFilter * stdev(kama1delta, length1) exitMAAF = exitFilter * stdev(kama1delta, length1) srcEma = ema(src, length1) //========================================= TRAILING ATR STOP ==================================== // The following is an adaptation of Trailing ATR Stops by @millerrh // He based it on scripts by @garethyeo & @SimpleCryptoLife // Inputs atrLookback = input(defval=14,title="Trailing ATR Lookback Period",type=input.integer) multiplier = input(defval=3,title="Trailing ATR Multiplier",type=input.float, step=0.1, minval=0.5, maxval=4) trailMode = input(title="Trail Mode", defval="Trailing", options=["Running", "Trailing"]) trigInput = input(title="Trigger Trailing Stop On", defval="Wick", options=["Close","Wick"]) // Calculate ATR atrValue = atr(atrLookback) atrMultiplied = atrValue * multiplier // Plot the price minus the ATR atrLow = low - atrMultiplied // Calculate the low trailing ATRs every time. The trailing stop loss never goes down. // Set them to something to start with trailAtrLow = atrLow // If the ATR Low has gone up AND it has gone above the trail, the low trailing ATR should also go up. If the ATR Low has gone up or down, but not below the trail, the ATR trail stays where it is trailAtrLow := na(trailAtrLow[1]) ? trailAtrLow : atrLow >= trailAtrLow[1] ? atrLow : trailAtrLow[1] // Trigger stop based on candle close or low trigSupport = trigInput == "Close" ? close : trigInput == "Wick" ? low : na // Determine if price is below support supportHit = trigSupport <= trailAtrLow // If price is below support, reset the trailing ATR trailAtrLow := supportHit ? atrLow : trailAtrLow // Plot Lines plotLow = ATRTSL ? trailAtrLow : na plot(plotLow, title="ATR Low", color=color.white, transp=50, style=plot.style_linebr, linewidth=1, display=display.all) //====================================== PSAR STOP ========================================== start = input(0.02, "PSAR Start") increment = input(0.02, "PSAR Increment") maximum = input(0.2, "PSAR Max Value") psar = sar(start, increment, maximum) psarPlot = PSARSL ? psar : na plot(psarPlot, "Parabolic SAR", style=plot.style_cross, color=#3A6CA8, display=display.all) //========================================= ENTRY & EXITS ===================================================== // Entry long = kama1delta > 0 and kama1delta > entryMAAF strategy.entry("Buy", true, when = long) // Close longClose = (PSARSL ? crossunder(close, psar) : na) or (KAMA1SL ? kama1delta < 0 and abs(kama1delta) > exitMAAF : na) or (ATRTSL ? supportHit : na) strategy.close("Buy", when = longClose, comment = "Sell")