এই কৌশলটি মাল্টিপ্লাইকেটিভ মুভিং মিডিয়ার লাইন গণনা করে এবং প্রবণতা দিক নির্ধারণের জন্য মূল্য এবং PMax সূচকটির ক্রসিংগুলিকে একত্রিত করে। এটি প্রবণতা বাড়ার সময় দীর্ঘ এবং প্রবণতা নেমে যাওয়ার সময় স্বল্পের জন্য দ্বি-নির্দেশ ট্রেডিং গ্রহণ করে, মুনাফা নিয়ে বেরিয়ে আসার জন্য রিয়েল টাইমে অবস্থানের ঝুঁকি মূল্যায়ন করে।
এই কৌশলটির মূল সূচক হ'ল গুণক চলমান গড় রেখা। সূচক পরামিতিগুলির মধ্যে রয়েছেঃ এটিআর সময়কাল, এটিআর গুণক, চলমান গড় প্রকার এবং দৈর্ঘ্য। এটিআর মান সময়ের মধ্যে অস্থিরতা উপস্থাপন করে। গুণক চলমান গড় রেখা গড় মূল্য প্লাস / বিয়োগের সমান। যখন দামটি লাইনের উপরে থাকে তখন একটি দীর্ঘ সংকেত থাকে। যখন দামটি লাইনের নীচে থাকে তখন একটি সংক্ষিপ্ত সংকেত থাকে।
PMax সূচকটি স্টপ লস বা লাভের মূল্যকে উপস্থাপন করে। এটি ATR মান এবং প্রবণতা দিক থেকে গণনা করা হয়। আপট্রেন্ডে, PMax চলমান গড় বিয়োগ ATR গুণক × ATR এর সমান, যা স্টপ লস লাইন হিসাবে কাজ করে। ডাউনট্রেন্ডে, PMax চলমান গড় প্লাস ATR গুণক × ATR এর সমান, যা লাভের লাইন হিসাবে কাজ করে।
যখন মূল্য PMax সূচকটি উপরে অতিক্রম করে তখন একটি দীর্ঘ সংকেত থাকে। যখন মূল্য PMax সূচকটি নীচে অতিক্রম করে তখন একটি সংক্ষিপ্ত সংকেত থাকে। কৌশলটি সংকেতগুলির উপর ভিত্তি করে প্রবেশ করে এবং প্রস্থান করে, আপট্রেন্ডে দীর্ঘ এবং ডাউনট্রেন্ডে সংক্ষিপ্ত হয়ে যায়, গতিশীল ট্রেলিং স্টপ লস এবং লাভ গ্রহণ করে।
এই কৌশলটির সুবিধাঃ
দ্বিমুখী ব্যবসায় গ্রহণের ফলে এটি বাজারের সমস্ত অবস্থার অত্যন্ত অন্তর্ভুক্তিমূলক।
মাল্টিপ্লাইকেটিভ মুভিং এভারেজ প্রয়োগ করলে স্থিতিশীল এবং নির্ভরযোগ্য ট্রেডিং সিগন্যাল পাওয়া যায়।
স্টপ লস/টেক প্রফিট এর জন্য PMax দিয়ে, এটি কার্যকরভাবে ঝুঁকি নিয়ন্ত্রণ করে।
নিয়মিত চক্র এবং মাল্টিপ্লায়ার প্যারামিটার এটিকে অত্যন্ত অভিযোজিত করে।
এছাড়াও কিছু ঝুঁকি আছেঃ
অনুপযুক্ত প্যারামিটার সেটিংগুলি হুইপসা ক্ষতির কারণ হতে পারে।
শর্ট শপিং করার সময় লিভারেজ লিমিট সম্পর্কে সতর্ক থাকুন।
ব্ল্যাক সোয়ান ইভেন্ট এড়ানো কঠিন।
সমাধান:
প্যারামিটার অপ্টিমাইজ করুন, যাতে হুইপস হ্রাস পায়।
সতর্কতার সাথে লিভারেজ নিয়ন্ত্রণ করুন এবং বৈচিত্র্য করুন।
স্টপ রেঞ্জ বাড়াতে ATR মাল্টিপ্লেকার বাড়ান।
কৌশলটি নিম্নলিখিত উপায়ে আপগ্রেড করা যেতে পারেঃ
বিভিন্ন বাজার এবং চক্র জুড়ে স্থিতিশীলতা পরীক্ষা করুন।
মেশিন লার্নিং প্রয়োগ করুন স্বয়ংক্রিয়ভাবে প্যারামিটার অপ্টিমাইজ করার জন্য.
ডিপ লার্নিং কৌশল ব্যবহার করে বাজার ব্যবস্থার মূল্যায়ন করুন।
সিদ্ধান্ত গ্রহণের ক্ষমতা বাড়ানোর জন্য আরো তথ্য উৎস একীভূত করা।
এই কৌশলটির সামগ্রিক পারফরম্যান্স শক্তিশালী অন্তর্ভুক্তির সাথে স্থিতিশীল। দ্বিমুখী বাণিজ্য এবং গতিশীল স্টপ লস / লাভ গ্রহণ গ্রহণ করে, এটি কার্যকরভাবে ঝুঁকি নিয়ন্ত্রণ করে। প্যারামিটার টিউনিং এবং মডেল পুনরাবৃত্তির মাধ্যমে কৌশল ফিটনেস এবং কার্যকারিতা আরও উন্নত করা যেতে পারে। সাধারণভাবে এটি একটি কৌশল যা দীর্ঘমেয়াদী মনোযোগ এবং প্রয়োগের মূল্যবান।
/*backtest start: 2023-01-08 00:00:00 end: 2024-01-14 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/ // © melihtuna //developer: @KivancOzbilgic //author: @KivancOzbilgic //stretegy converter: @crypto_melih //@version=4 strategy("Profit Maximizer Strategy Long-Short", shorttitle="PMax-Strategy", overlay=true, default_qty_type=strategy.cash, default_qty_value=10000, initial_capital=10000, currency=currency.USD, commission_value=0, commission_type=strategy.commission.percent) src = input(hl2, title="Source") Periods = input(title="ATR Length", type=input.integer, defval=10) Multiplier = input(title="ATR Multiplier", type=input.float, step=0.1, defval=3.0) mav = input(title="Moving Average Type", defval="EMA", options=["SMA", "EMA", "WMA", "TMA", "VAR", "WWMA", "ZLEMA", "TSF"]) length =input(10, "Moving Average Length", minval=1) condition = input(title="Signal Type", defval="Only Crossing Signals", options=["Only Crossing Signals", "Only Price/Pmax Crossing Signals"]) changeATR= input(title="Change ATR Calculation Method ?", type=input.bool, defval=true) showsupport = input(title="Show Moving Average?", type=input.bool, defval=true) //showsignalsk = input(title="Show Crossing Signals?", type=input.bool, defval=true) //showsignalsc = input(title="Show Price/Pmax Crossing Signals?", type=input.bool, defval=false) highlighting = input(title="Highlighter On/Off ?", type=input.bool, defval=true) long_short = input(defval = false, title = "Long-Short", type=input.bool) atr2 = sma(tr, Periods) atr= changeATR ? atr(Periods) : atr2 valpha=2/(length+1) vud1=src>src[1] ? src-src[1] : 0 vdd1=src<src[1] ? src[1]-src : 0 vUD=sum(vud1,9) vDD=sum(vdd1,9) vCMO=nz((vUD-vDD)/(vUD+vDD)) VAR=0.0 VAR:=nz(valpha*abs(vCMO)*src)+(1-valpha*abs(vCMO))*nz(VAR[1]) wwalpha = 1/ length WWMA = 0.0 WWMA := wwalpha*src + (1-wwalpha)*nz(WWMA[1]) zxLag = length/2==round(length/2) ? length/2 : (length - 1) / 2 zxEMAData = (src + (src - src[zxLag])) ZLEMA = ema(zxEMAData, length) lrc = linreg(src, length, 0) lrc1 = linreg(src,length,1) lrs = (lrc-lrc1) TSF = linreg(src, length, 0)+lrs getMA(src, length) => ma = 0.0 if mav == "SMA" ma := sma(src, length) ma if mav == "EMA" ma := ema(src, length) ma if mav == "WMA" ma := wma(src, length) ma if mav == "TMA" ma := sma(sma(src, ceil(length / 2)), floor(length / 2) + 1) ma if mav == "VAR" ma := VAR ma if mav == "WWMA" ma := WWMA ma if mav == "ZLEMA" ma := ZLEMA ma if mav == "TSF" ma := TSF ma ma MAvg=getMA(src, length) longStop = MAvg - Multiplier*atr longStopPrev = nz(longStop[1], longStop) longStop := MAvg > longStopPrev ? max(longStop, longStopPrev) : longStop shortStop = MAvg + Multiplier*atr shortStopPrev = nz(shortStop[1], shortStop) shortStop := MAvg < shortStopPrev ? min(shortStop, shortStopPrev) : shortStop dir = 1 dir := nz(dir[1], dir) dir := dir == -1 and MAvg > shortStopPrev ? 1 : dir == 1 and MAvg < longStopPrev ? -1 : dir PMax = dir==1 ? longStop: shortStop plot(showsupport ? MAvg : na, color=#0585E1, linewidth=2, title="Moving Avg Line") pALL=plot(PMax, color=color.red, linewidth=2, title="PMax", transp=0) alertcondition(cross(MAvg, PMax), title="Cross Alert", message="PMax - Moving Avg Crossing!") alertcondition(crossover(MAvg, PMax), title="Crossover Alarm", message="Moving Avg BUY SIGNAL!") alertcondition(crossunder(MAvg, PMax), title="Crossunder Alarm", message="Moving Avg SELL SIGNAL!") alertcondition(cross(src, PMax), title="Price Cross Alert", message="PMax - Price Crossing!") alertcondition(crossover(src, PMax), title="Price Crossover Alarm", message="PRICE OVER PMax - BUY SIGNAL!") alertcondition(crossunder(src, PMax), title="Price Crossunder Alarm", message="PRICE UNDER PMax - SELL SIGNAL!") buySignalk = crossover(MAvg, PMax) //plotshape(buySignalk and showsignalsk ? PMax*0.995 : na, title="Buy", text="Buy", location=location.absolute, style=shape.labelup, size=size.tiny, color=color.green, textcolor=color.white, transp=0) sellSignallk = crossunder(MAvg, PMax) //plotshape(sellSignallk and showsignalsk ? PMax*1.005 : na, title="Sell", text="Sell", location=location.absolute, style=shape.labeldown, size=size.tiny, color=color.red, textcolor=color.white, transp=0) buySignalc = crossover(src, PMax) //plotshape(buySignalc and showsignalsc ? PMax*0.995 : na, title="Buy", text="Buy", location=location.absolute, style=shape.labelup, size=size.tiny, color=#0F18BF, textcolor=color.white, transp=0) sellSignallc = crossunder(src, PMax) //plotshape(sellSignallc and showsignalsc ? PMax*1.005 : na, title="Sell", text="Sell", location=location.absolute, style=shape.labeldown, size=size.tiny, color=#0F18BF, textcolor=color.white, transp=0) mPlot = plot(ohlc4, title="", style=plot.style_circles, linewidth=0,display=display.none) longFillColor = highlighting ? (MAvg>PMax ? color.green : na) : na shortFillColor = highlighting ? (MAvg<PMax ? color.red : na) : na fill(mPlot, pALL, title="UpTrend Highligter", color=longFillColor) fill(mPlot, pALL, title="DownTrend Highligter", color=shortFillColor) if(condition=="Only Crossing Signals") strategy.entry("BUY", strategy.long, when = buySignalk) else strategy.entry("BUY", strategy.long, when = buySignalc) if(long_short) if(condition=="Only Crossing Signals") strategy.entry("SELL", strategy.short, when = sellSignallk) else strategy.entry("SELL", strategy.short, when = sellSignallc) else if(condition=="Only Crossing Signals") strategy.close("BUY", when = sellSignallk) else strategy.close("BUY", when = sellSignallc)