EMA ডবল মুভিং এভারেজ ক্রসওভার ডাইনামিক স্টপ-প্রফিট এবং স্টপ-লস পরিমাণগত ট্রেডিং কৌশল

EMA
সৃষ্টির তারিখ: 2024-11-18 15:53:49 অবশেষে সংশোধন করুন: 2024-11-18 15:53:49
অনুলিপি: 5 ক্লিকের সংখ্যা: 611
1
ফোকাস
1617
অনুসারী

ওভারভিউ

এই কৌশলটি একটি পরিমাণগত ট্রেডিং সিস্টেম যা সমান্তরাল ক্রস-ভিত্তিক এবং একটি গতিশীল স্টপ-অফ-লস মেশিনের সাথে যুক্ত। কৌশলটির মূলটি হ’ল 10 চক্র এবং 26 চক্রের সূচকটি মুভিং গড় ((EMA) এর ক্রস-অফের মাধ্যমে বাজার প্রবণতা সনাক্ত করা এবং বিপর্যয়ের সময় লেনদেন করা। সিস্টেমটি স্থির স্টপ-অফ-লস পয়েন্ট সেটআপ ব্যবহার করে, কঠোর ঝুঁকি নিয়ন্ত্রণের মাধ্যমে তহবিল সুরক্ষিত করে। এই কৌশলটি বিশেষত উচ্চতর ওঠানামাপূর্ণ ট্রেডিং জাতের জন্য উপযুক্ত, কারণ এই ধরণের পণ্যগুলি প্রায়শই আরও পরিষ্কার বাজার বিপরীত সংকেত এবং বৃহত্তর লাভের সুযোগ সরবরাহ করে।

কৌশল নীতি

কৌশলটি দুটি ভিন্ন পিরিয়ডের ইএমএ গড়কে কেন্দ্রীয় সূচক হিসাবে ব্যবহার করেঃ স্বল্পমেয়াদী 10 পিরিয়ড ইএমএ এবং দীর্ঘমেয়াদী 26 পিরিয়ড ইএমএ। যখন স্বল্পমেয়াদী গড়টি দীর্ঘমেয়াদী গড়কে অতিক্রম করে, সিস্টেমটি একটি ক্রয় সংকেত উত্পন্ন করে। যখন স্বল্পমেয়াদী গড়টি দীর্ঘমেয়াদী গড়কে অতিক্রম করে, সিস্টেমটি একটি ডাউন ট্রেন্ড হিসাবে চিহ্নিত করে, একটি বিক্রয় সংকেত উত্পন্ন করে। সিস্টেমটি একটি ট্রেন্ড নিশ্চিত করার পরে, দামের পুনরুদ্ধারের জন্য অপেক্ষা করে এবং 30 পয়েন্ট স্টপ এবং 15 পয়েন্ট স্টপ নিয়ন্ত্রণ করে। কৌশলটি একটি একক সংকেত ব্যবস্থা গ্রহণ করে, যা একই সময়ে কেবলমাত্র এক দিকের লেনদেনের অনুমতি দেয়, যা সিস্টেমের জটিলতা হ্রাস করতে এবং নির্ভরযোগ্যতা বাড়াতে সহায়তা করে।

কৌশলগত সুবিধা

  1. সংকেত স্পষ্টতাঃ ট্রেডিং সিগন্যাল হিসাবে সমান্তরাল ক্রস ব্যবহার করে, নিয়মগুলি সহজ এবং স্পষ্ট, কার্যকর করা এবং নিরীক্ষণ করা সহজ
  2. ঝুঁকি নিয়ন্ত্রণযোগ্যঃ স্টপ লস পয়েন্টের একটি নির্দিষ্ট স্টপ-আপ রয়েছে যা প্রতিটি লেনদেনের ঝুঁকিকে কার্যকরভাবে নিয়ন্ত্রণ করে
  3. প্রবণতা ট্র্যাকিংঃ সমান্তরাল ক্রসিং এবং মূল্য পুনর্নির্ধারণের সাথে মিলিত হয়ে প্রবণতা সম্পর্কে আরও ভাল ধারণা অর্জন করা
  4. স্বয়ংক্রিয়তার উচ্চ স্তরঃ কৌশলগত যুক্তি পরিষ্কার, স্বয়ংক্রিয় লেনদেনের জন্য প্রোগ্রাম করা সহজ
  5. দৃঢ়তাঃ বিভিন্ন ট্রেডিং জাতের জন্য উপযুক্ত, বিশেষত উচ্চতর ওঠানামা সহ

কৌশলগত ঝুঁকি

  1. বাজারের ঝড়ের ঝুঁকিঃ বাজারের ঝড়ের মধ্যে মিথ্যা সংকেত ঘন ঘন হতে পারে
  2. স্লাইড পয়েন্টের ঝুঁকিঃ বাজারের তীব্র অস্থিরতার সময় বড় স্লাইড পয়েন্ট হতে পারে
  3. স্টপ লস ঝুঁকিঃ নির্দিষ্ট বাজারের পরিস্থিতিতে স্টপ লস স্থির করা কঠিন হতে পারে
  4. সিগন্যাল লেগঃ সমান্তরাল ক্রস সিগন্যালের একটি নির্দিষ্ট লেগ থাকে, যা সেরা প্রবেশের পয়েন্টটি মিস করতে পারে
  5. তহবিল ব্যবস্থাপনা ঝুঁকিঃ প্রতিটি লেনদেনের জন্য তহবিলের অনুপাতের উপর যুক্তিসঙ্গত নিয়ন্ত্রণ প্রয়োজন

কৌশল অপ্টিমাইজেশনের দিকনির্দেশনা

  1. ডায়নামিক স্টপঃ বাজারের ওঠানামা অনুযায়ী ডায়নামিকভাবে স্টপ পজিশনের পরিবর্তন বিবেচনা করা যেতে পারে
  2. সিগন্যাল ফিল্টারিংঃ ভুয়া সংকেত ফিল্টার করার জন্য ট্র্যাফিক, ওঠানামা এবং অন্যান্য সহায়ক সূচক বৃদ্ধি করা
  3. টাইম ফিল্টারিংঃ ট্রেডিংয়ের সময়কাল ফিল্টারিং বাড়ান, উচ্চ ওঠানামা এড়ানোর জন্য
  4. পজিশন ম্যানেজমেন্টঃ ট্রেন্ড ট্র্যাকিং চালিয়ে যাওয়ার জন্য কিছু পজিশন সংরক্ষণের অনুমতি দেওয়ার জন্য একটি আংশিক স্টপ-অফ ব্যবস্থা যুক্ত করা হয়েছে
  5. তহবিল ব্যবস্থাপনাঃ অ্যাকাউন্টের নেট মূল্যের উপর ভিত্তি করে লেনদেনের আকার স্বয়ংক্রিয়ভাবে সামঞ্জস্য করার জন্য একটি গতিশীল তহবিল ব্যবস্থাপনা সিস্টেম যুক্ত করা হয়েছে

সারসংক্ষেপ

এই কৌশলটি ইএমএ সমান্তরাল ক্রস এবং মূল্যের রিডাকশনের সাথে একত্রিত হয়ে একটি সম্পূর্ণ ট্রেডিং সিস্টেম তৈরি করে। কৌশলটি সহজ এবং স্বজ্ঞাতভাবে ডিজাইন করা হয়েছে, ঝুঁকি নিয়ন্ত্রণটি সুস্পষ্ট, এবং এটি উচ্চতর ওঠানামাযুক্ত ট্রেডিং জাতের জন্য উপযুক্ত। যুক্তিসঙ্গত অপ্টিমাইজেশন এবং প্যারামিটার সমন্বয়ের মাধ্যমে, কৌশলটি রিয়েল-স্টোর ট্রেডিংয়ে স্থিতিশীল উপার্জনের প্রত্যাশা করে। ব্যবসায়ীদের রিয়েল-স্টোর ব্যবহারের আগে পর্যাপ্ত পরিমাণে পুনর্বিবেচনা এবং মডেল ট্রেডিং করার পরামর্শ দেওয়া হয় এবং প্রকৃত পরিস্থিতি অনুসারে প্যারামিটারগুলির জন্য অনুকূলিতকরণ করা হয়।

কৌশল সোর্স কোড
/*backtest
start: 2023-11-18 00:00:00
end: 2024-11-17 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=5
strategy("30 Pips Target & 15 Pips Stop-Loss with One Signal at a Time", overlay=true)

// Define settings for target and stop-loss in pips
target_in_pips = 30
stoploss_in_pips = 10

// Convert pips to price value based on market (for forex, 1 pip = 0.0001 for major pairs like GBP/JPY)
pip_value = syminfo.mintick * 10  // For forex, 1 pip = 0.0001 or 0.01 for JPY pairs
target_value = target_in_pips * pip_value
stoploss_value = stoploss_in_pips * pip_value

// Define EMAs (10-EMA and 26-EMA) for the crossover strategy
ema10 = ta.ema(close, 10)
ema26 = ta.ema(close, 26)

// Buy signal: when 10 EMA crosses above 26 EMA
longCondition = ta.crossover(ema10, ema26)
// Sell signal: when 10 EMA crosses below 26 EMA
shortCondition = ta.crossunder(ema10, ema26)

// Define price levels with explicit type float
var float long_entry_price = na
var float long_take_profit = na
var float long_stop_loss = na
var float short_entry_price = na
var float short_take_profit = na
var float short_stop_loss = na

// Variable to track if a trade is active
var bool inTrade = false

// Check if the trade hit stop loss or take profit
if (inTrade)
    if (not na(long_take_profit) and close >= long_take_profit)
        inTrade := false  // Exit the trade after hitting target
        long_entry_price := na
        long_take_profit := na
        long_stop_loss := na
        strategy.close("Long")

    if (not na(long_stop_loss) and close <= long_stop_loss)
        inTrade := false  // Exit the trade after hitting stoploss
        long_entry_price := na
        long_take_profit := na
        long_stop_loss := na
        strategy.close("Long")

    if (not na(short_take_profit) and close <= short_take_profit)
        inTrade := false  // Exit the trade after hitting target
        short_entry_price := na
        short_take_profit := na
        short_stop_loss := na
        strategy.close("Short")

    if (not na(short_stop_loss) and close >= short_stop_loss)
        inTrade := false  // Exit the trade after hitting stoploss
        short_entry_price := na
        short_take_profit := na
        short_stop_loss := na
        strategy.close("Short")

// Only generate new signals if not already in a trade
if (not inTrade)
    if (longCondition)
        long_entry_price := close
        long_take_profit := close + target_value
        long_stop_loss := close - stoploss_value
        strategy.entry("Long", strategy.long)  // Enter a long trade
        strategy.exit("Take Profit/Stop Loss", "Long", limit=long_take_profit, stop=long_stop_loss)
        inTrade := true  // Mark trade as active

    if (shortCondition)
        short_entry_price := close
        short_take_profit := close - target_value
        short_stop_loss := close + stoploss_value
        strategy.entry("Short", strategy.short)  // Enter a short trade
        strategy.exit("Take Profit/Stop Loss", "Short", limit=short_take_profit, stop=short_stop_loss)
        inTrade := true  // Mark trade as active

// Plot the levels on the chart only when in a trade
plot(inTrade and not na(long_take_profit) ? long_take_profit : na, color=color.green, linewidth=2, style=plot.style_linebr, title="Take Profit (Long)")
plot(inTrade and not na(long_stop_loss) ? long_stop_loss : na, color=color.red, linewidth=2, style=plot.style_linebr, title="Stop Loss (Long)")

plot(inTrade and not na(short_take_profit) ? short_take_profit : na, color=color.green, linewidth=2, style=plot.style_linebr, title="Take Profit (Short)")
plot(inTrade and not na(short_stop_loss) ? short_stop_loss : na, color=color.red, linewidth=2, style=plot.style_linebr, title="Stop Loss (Short)")

plotshape(series=longCondition and not inTrade, title="Buy Signal", location=location.belowbar, color=color.green, style=shape.labelup, text="Buy")
plotshape(series=shortCondition and not inTrade, title="Sell Signal", location=location.abovebar, color=color.red, style=shape.labeldown, text="Sell")