ভলিউম মূল্য নিশ্চিতকরণ কৌশল সহ উন্নত রিট্রেসমেন্ট ট্রেডিং ট্রায়াঙ্গেল ব্রেকআউট

SMA RSI TSL EMA 三角形突破 交易量确认 动态止损 趋势跟踪 斐波那契
সৃষ্টির তারিখ: 2025-06-03 09:57:46 অবশেষে সংশোধন করুন: 2025-06-03 09:57:46
অনুলিপি: 0 ক্লিকের সংখ্যা: 314
2
ফোকাস
319
অনুসারী

ভলিউম মূল্য নিশ্চিতকরণ কৌশল সহ উন্নত রিট্রেসমেন্ট ট্রেডিং ট্রায়াঙ্গেল ব্রেকআউট ভলিউম মূল্য নিশ্চিতকরণ কৌশল সহ উন্নত রিট্রেসমেন্ট ট্রেডিং ট্রায়াঙ্গেল ব্রেকআউট

ওভারভিউ

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

কৌশল নীতি

এই কৌশলটি দুটি মূল প্রবেশের সেটিং এবং একটি সুনির্দিষ্টভাবে পরিকল্পিত প্রস্থান পদ্ধতির উপর ভিত্তি করে কাজ করেঃ

প্রবেশদ্বার সেটিং 1 - গোল্ডেন ট্রায়াঙ্গল ব্রেকআউট

  • ত্রিভুজ আকৃতি সনাক্তকরণের জন্য নিকটতম উচ্চ-নিম্ন অক্ষ ব্যবহার করুন
  • যখন দাম ত্রিভুজের শীর্ষের উপরে এবং একই সাথে 50 পিরিয়ডের এসএমএর উপরে বন্ধ হয়, তখন পজিটিভ ব্রেকিং নিশ্চিত করা হয়
  • ব্রেকডাউন শেষে খেলায় যোগদান
  • এই সেটিংটি বিশেষভাবে সমন্বয়কালের পরে প্রাথমিক ভলিউম ট্রেডিংয়ের জন্য উপযুক্ত

এন্ট্রি সেটিং 2 - মূল্য এবং লেনদেনের পরিমাণ নিশ্চিতকরণ

  • ট্রেডিং ভলিউমের উপর ভিত্তি করে গড় মূল্যের রিটার্নঃ
    • দাম প্রথমে ৫০ এসএমএর নিচে নেমে আসে, তারপর আবার ওপরে ফিরে আসে
    • কমপক্ষে একটি “উন্নয়ন দিবস” প্রয়োজন ((বর্তমান সমাপ্তি মূল্য পূর্ববর্তী সমাপ্তি মূল্যের চেয়ে বেশি)
    • ট্রেডিং ভলিউম অবশ্যই তার 50 চক্রের এসএমএর চেয়ে বেশি হতে হবে এবং আগের 4 দিনের প্রতিটি দিনের চেয়ে বেশি হতে হবে
  • ট্রেডিং নিশ্চিতকরণের দিন বন্ধের সময় প্রবেশ করুন
  • বিশেষত কার্যকর যখন ত্রিভুজ প্যাটার্ন অস্পষ্ট কিন্তু শক্তিশালী জমা হয়

প্রস্থান কৌশল - গতিশীল ট্র্যাকিং স্টপ

  • প্রারম্ভিক স্টপ লস সেট করা হয়েছে সর্বোচ্চ মূল্যের ১০% এর নিচে
  • যখন মুনাফা ১০% হয়, ট্র্যাকিং স্টপ লস ৫% হয়
  • এই প্রক্রিয়াটি ব্যবসায়ীদের মুনাফা বজায় রাখার সাথে সাথে ট্রেন্ড ধরে রাখার অনুমতি দেয়

কোড বাস্তবায়নের ক্ষেত্রে, কৌশলটি একটি সরলীকৃত কেন্দ্রীয় পয়েন্ট ব্যবহার করে ত্রিভুজ আকৃতি সনাক্ত করে এবং বর্তমান মূল্যের সাথে এসএমএর তুলনা করে দামের গতি নিশ্চিত করে। লেনদেনের পরিমাণ নিশ্চিত করার জন্য, কৌশলটি পরীক্ষা করে যে লেনদেনের পরিমাণ তার চলমান গড়ের চেয়ে বেশি কিনা এবং পূর্ববর্তী কয়েক চক্রের লেনদেনের পরিমাণ। গতিশীল ট্র্যাকিং স্টপ লস লেনদেনের সর্বোচ্চ মূল্যের সাথে ক্রমাগত আপডেট করে এবং সংশ্লিষ্ট স্টপ লস স্তর গণনা করে।

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

  1. দ্বৈত প্রবেশ পদ্ধতি: দুটি স্বতন্ত্র প্রবেশের সেটিং সরবরাহ করে, কৌশলটি বিভিন্ন বাজারের পরিবেশের সাথে খাপ খাইয়ে নিতে সক্ষম হয়, লাভজনক ব্যবসায়ের সুযোগগুলি ধরার সম্ভাবনা বাড়ায়। যখন বাজারটি সুস্পষ্ট সংহতকরণের সময়কালে থাকে, সেটিং 1 বিপর্যয়কে ধরতে পারে; যখন বাজার প্যাটার্নটি কম সুস্পষ্ট হয় তবে শক্তিশালী সংযোজনীয় লক্ষণ থাকে, তখন সেটিং 2 কার্যকর হতে পারে।

  2. ঝুঁকি ব্যবস্থাপনার সমন্বয়বিল্ট-ইন ডায়নামিক ট্র্যাকিং স্টপ লস মেশিনটি বাজারের অস্থিরতার সাথে স্বয়ংক্রিয়ভাবে মানিয়ে নেয় এবং মূলধনকে সুরক্ষিত করার সময় মুনাফা বৃদ্ধি করতে দেয়। বিশেষত যখন মুনাফা একটি পূর্বনির্ধারিত থ্রেশহোল্ডে পৌঁছে যায় তখন স্বয়ংক্রিয়ভাবে স্টপ লস ফাংশনটি কার্যকরভাবে মুনাফা লক করার এবং মুনাফা চালানোর দ্বন্দ্বকে ভারসাম্য দেয়।

  3. ফিল্টার ভুয়া অনুপ্রবেশ: এসএমএ ফিল্টারিং এবং ট্রেডিং ভলিউম নিশ্চিতকরণের সমন্বয়ে, কৌশলটি মিথ্যা ব্রেকআউটের ঝুঁকি হ্রাস করে। দামগুলিকে অবশ্যই কেবল প্যাটার্নটি ভেঙে ফেলতে হবে না, তবে এসএমএর উপরেও থাকতে হবে, সেটিং 2 এর জন্য উল্লেখযোগ্য পরিমাণে ট্রেডিং সমর্থন প্রয়োজন, যা সংকেতের গুণমানকে ব্যাপকভাবে উন্নত করে।

  4. ভিজ্যুয়াল সহায়তা: কৌশলটি প্রচুর পরিমাণে ভিজ্যুয়াল সূচক সরবরাহ করে, যার মধ্যে ট্রেডিংয়ের সময় ব্যাকগ্রাউন্ড কালারিং, রিয়েল-টাইম ডেক্সটপ এবং বিভিন্ন অঙ্কন উপাদান রয়েছে, যা ব্যবসায়ীদের সহজেই কৌশল স্থিতি এবং সংকেত পর্যবেক্ষণ করতে দেয়।

  5. নমনীয় সময় ফ্রেম অপ্টিমাইজেশান: যদিও কৌশলটি 1 ঘন্টার চার্টের জন্য অপ্টিমাইজ করা হয়েছে, তবে এর প্যারামিটারগুলি বিভিন্ন সময় ফ্রেমের সাথে খাপ খাইয়ে নিতে পারে, যা কৌশলটির প্রয়োগের সুযোগ বাড়িয়ে তোলে।

কৌশলগত ঝুঁকি

  1. বাজার নির্ভরতা: এই কৌশলটি ঊর্ধ্বমুখী বা মুদ্রাস্ফীতির বাজারগুলিতে সর্বোত্তমভাবে কাজ করে এবং তীব্র নিম্নমুখী বা উচ্চ অস্থিরতার বাজারগুলিতে খারাপ কাজ করতে পারে। একটি ভাল বাজারের পরিবেশে, ভুয়া ব্রেকআউটের ঝুঁকি বৃদ্ধি পায়, যা ধারাবাহিক ক্ষতির কারণ হতে পারে।

  2. স্লাইড পয়েন্ট এবং বাস্তবায়ন ঝুঁকি: প্রকৃত লেনদেনের সময়, বিশেষত কম তরল বাজারে, এন্ট্রি এবং স্টপ লস পয়েন্টগুলি স্লাইড পয়েন্টের সম্মুখীন হতে পারে যা কৌশলটির সামগ্রিক কার্যকারিতা প্রভাবিত করে। এই ঝুঁকি কমাতে, বাজার মূল্যের পরিবর্তে সীমিত মূল্যের তালিকা ব্যবহার করা বিবেচনা করা যেতে পারে।

  3. প্যারামিটার অপ্টিমাইজেশান চ্যালেঞ্জকৌশলটি একাধিক প্যারামিটারের উপর নির্ভর করে (যেমন এসএমএ দৈর্ঘ্য, স্টপডাউন শতাংশ ইত্যাদি) এবং এই প্যারামিটারগুলিকে নির্দিষ্ট বাজার এবং সময় ফ্রেমের জন্য অনুকূলিতকরণ করা দরকার। অযৌক্তিক প্যারামিটার সেটগুলি অতিরিক্ত ফিট বা দুর্বল পারফরম্যান্সের কারণ হতে পারে।

  4. অতিরিক্ত লেনদেনের ঝুঁকি: কিছু বাজারের অবস্থার অধীনে, কৌশলগুলি অতিরিক্ত সংকেত তৈরি করতে পারে, যার ফলে অতিরিক্ত লেনদেন এবং লেনদেনের ব্যয় বৃদ্ধি পায়। অতিরিক্ত ফিল্টার বা শীতল সময় প্রয়োগ করা এই ঝুঁকি হ্রাস করতে সহায়তা করতে পারে।

  5. স্টপ লস অপ্টিমাইজেশান ভারসাম্য: যদিও ডায়নামিক স্টপ-অফ ব্যবস্থাটি এই কৌশলটির একটি সুবিধা, তবে স্টপ-অফ সেটিংটি খুব টাইট হলে এটি লাভজনক ব্যবসায়ের অগ্রিম প্রস্থান করতে পারে, এবং এটি খুব প্রশস্ত হলে এটি লাভের রিটার্ন করতে পারে। নির্দিষ্ট বাজারের অস্থিরতার উপর নির্ভর করে স্টপ-অফ প্যারামিটারগুলিকে সাবধানে সামঞ্জস্য করতে হবে।

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

  1. ট্রেন্ড ফিল্টার যোগ করুন: বিস্তৃত প্রবণতা সূচক (যেমন একটি দীর্ঘমেয়াদী চলমান গড় বা ADX) সংহত করা কৌশলকে কেবলমাত্র অনুকূল বাজার দিকের দিকে ট্রেড করতে সহায়তা করতে পারে। উদাহরণস্বরূপ, একটি শর্ত যুক্ত করা যেতে পারে যা কেবলমাত্র দীর্ঘমেয়াদী এসএমএ (যেমন 200 চক্রের মতো) ঊর্ধ্বমুখী হলেই মুদ্রাস্ফীতি প্রবেশের অনুমতি দেয়।

  2. লেনদেনের ভলিউম নিশ্চিতকরণ লজিক অনুকূলিতকরণ: বর্তমান ট্রেডিং ভলিউম নিশ্চিতকরণের জন্য পূর্ববর্তী 4 টি চক্রের চেয়ে বেশি ট্রেডিং ভলিউম প্রয়োজন, যা বাজার অবস্থার উপর নির্ভর করে খুব কঠোর বা যথেষ্ট কঠোর হতে পারে। ট্রেডিং ভলিউমের স্বনির্ধারণের জন্য স্বনির্ধারণযোগ্যতা অর্জন করুন, বাজারের অস্থিরতার গতিশীলতার সাথে সামঞ্জস্য রেখে সেটিং 2 এর কার্যকারিতা বাড়িয়ে তুলুন।

  3. ইন্টিগ্রেটেড টাইম ফিল্টারকিছু ট্রেডিং সময় অন্য সময়ের তুলনায় এই কৌশলটির জন্য আরও উপযুক্ত হতে পারে। সময় ফিল্টার যুক্ত করা, প্রতিকূল সময়ে (যেমন বাজারের খোলার বা বন্ধ হওয়ার আগে উচ্চ ওঠানামা) ট্রেডিং এড়ানো, সামগ্রিক কর্মক্ষমতা উন্নত করতে পারে।

  4. আংশিক মুনাফা লকিংবর্তমান প্রস্থান কৌশলটি দ্বৈত (খুব বেশি বা সম্পূর্ণ প্রস্থান) । একটি ব্যাচ প্রস্থান সিস্টেম বাস্তবায়ন করে, মুনাফা বাড়ার সাথে সাথে ধীরে ধীরে অবস্থানের আকার হ্রাস করে, কিছু উপরের সম্ভাব্যতা সংরক্ষণ করার সময় আংশিক মুনাফা লক করা যায়।

  5. সংশ্লিষ্ট সম্পত্তি নিশ্চিতকরণ যোগ করুন: কিছু বাজারে, প্রাসঙ্গিক সম্পদের নিশ্চিতকরণ সংকেতের গুণমান বাড়িয়ে তুলতে পারে। উদাহরণস্বরূপ, শেয়ার ব্যবসায়ের ক্ষেত্রে, একটি সেক্টর বা শিল্পের শক্তি অতিরিক্ত ফিল্টার হিসাবে কাজ করতে পারে; ফরেক্সে, প্রাসঙ্গিক মুদ্রা জোড়ার আচরণ অতিরিক্ত নিশ্চিতকরণ সরবরাহ করতে পারে।

  6. বাজারের অস্থিরতা সমন্বয়: বাজারের অস্থিরতার উপর ভিত্তি করে স্টপ লেভেলের গতিশীল সমন্বয় (যেমন এটিআর বা historicalতিহাসিক অস্থিরতা) কৌশলকে বিভিন্ন বাজারের অবস্থার সাথে আরও ভালভাবে খাপ খাইয়ে নিতে পারে। কম অস্থিরতার পরিবেশে আরও টাইট স্টপ ব্যবহার করুন এবং উচ্চ অস্থিরতার পরিবেশে আরও প্রশস্ত স্টপ ব্যবহার করুন।

সারসংক্ষেপ

উচ্চ পর্যায়ের প্রত্যাহারের ট্রেডিং ত্রিভুজ ব্রেকআউট এবং ভলিউম কনফার্মেশন কৌশলটি একটি সামগ্রিক ট্রেডিং পদ্ধতি সরবরাহ করে যা প্রযুক্তিগত ফর্ম্যাট সনাক্তকরণ, গতিশীলতা নীতি এবং লেনদেনের পরিমাণ বিশ্লেষণের সাথে মিলিত হয়। দুটি পরিপূরক প্রবেশের সেটিং সরবরাহ করে, কৌশলটি বিভিন্ন বাজারের অবস্থার মধ্যে নমনীয়তা বজায় রাখে, এবং এর গতিশীল ট্র্যাকিং স্টপ লস প্রক্রিয়াটি অপ্টিমাইজড ঝুঁকি ব্যবস্থাপনা সরবরাহ করে।

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

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

কৌশল সোর্স কোড
/*backtest
start: 2024-06-03 00:00:00
end: 2025-06-02 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"ETH_USDT"}]
*/

// This Pine Script® code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © eemani123

//@version=5
strategy("Golden Triangle Strategy (1H, Setup 1 & 2)", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=100)

// === Inputs ===
smaLength = input.int(34, title="SMA Length (1H Optimized)", minval=1)
volumeSmaLength = input.int(34, title="Volume SMA Length", minval=1)
trailingStopPct = input.float(6.0, title="Initial Trailing Stop Loss (%)", minval=0.1)
tightenPct = input.float(5.0, title="Tightened TSL (%)", minval=0.1)
profitTrigger = input.float(10.0, title="Tighten TSL After Profit (%)", minval=1)
maxLookback = input.int(10, title="Max Lookback Bars for Setup 2", minval=1)
pivotStrength = input.int(2, title="Pivot Strength (Shorter for 1H)", minval=1)

// === SMA Calculations ===
smaPrice = ta.sma(close, smaLength)
smaVolume = ta.sma(volume, volumeSmaLength)

// === Setup 1: Golden Triangle (simplified with pivots) ===
pivotHigh = ta.pivothigh(high, pivotStrength, pivotStrength)
pivotLow = ta.pivotlow(low, pivotStrength, pivotStrength)

var float triangleTop = na
var float triangleBottom = na

if not na(pivotHigh)
    triangleTop := pivotHigh
if not na(pivotLow)
    triangleBottom := pivotLow

triangleBreakout = ta.crossover(close, triangleTop) and close > smaPrice
enterSetup1 = triangleBreakout

// === Setup 2: Price & Volume Confirmation ===
priceBelowSMA = ta.barssince(close < smaPrice) <= maxLookback
priceConfirm = close > smaPrice and close > close[1]
volumeConfirm = volume > smaVolume and volume > volume[1] and volume > volume[2] and volume > volume[3] and volume > volume[4]
enterSetup2 = priceConfirm and priceBelowSMA and volumeConfirm

// === Entry & TSL Tracking ===
var bool inTradeSetup1 = false
var bool inTradeSetup2 = false
var float entryPrice1 = na
var float entryPrice2 = na
var float highestSinceEntry1 = na
var float highestSinceEntry2 = na
var float trailingStop1 = na
var float trailingStop2 = na

// === Entry Conditions ===
if enterSetup1 and not inTradeSetup1
    strategy.entry("Buy Setup 1", strategy.long)
    entryPrice1 := close
    highestSinceEntry1 := close
    inTradeSetup1 := true

if enterSetup2 and not inTradeSetup2
    strategy.entry("Buy Setup 2", strategy.long)
    entryPrice2 := close
    highestSinceEntry2 := close
    inTradeSetup2 := true

// === Update Trailing Stops with Tightening ===
if inTradeSetup1
    highestSinceEntry1 := math.max(highestSinceEntry1, high)
    profit1 = (highestSinceEntry1 - entryPrice1) / entryPrice1 * 100
    activePct1 = profit1 >= profitTrigger ? tightenPct : trailingStopPct
    trailingStop1 := highestSinceEntry1 * (1 - activePct1 / 100)

if inTradeSetup2
    highestSinceEntry2 := math.max(highestSinceEntry2, high)
    profit2 = (highestSinceEntry2 - entryPrice2) / entryPrice2 * 100
    activePct2 = profit2 >= profitTrigger ? tightenPct : trailingStopPct
    trailingStop2 := highestSinceEntry2 * (1 - activePct2 / 100)

// === Exit Conditions ===
if inTradeSetup1 and close < trailingStop1
    strategy.close("Buy Setup 1", comment="TSL Hit - Setup 1")
    inTradeSetup1 := false
    entryPrice1 := na
    highestSinceEntry1 := na
    trailingStop1 := na

if inTradeSetup2 and close < trailingStop2
    strategy.close("Buy Setup 2", comment="TSL Hit - Setup 2")
    inTradeSetup2 := false
    entryPrice2 := na
    highestSinceEntry2 := na
    trailingStop2 := na

// === Plotting ===
plot(smaPrice, color=color.orange, title="SMA")
//plot(triangleTop, title="Triangle Top", color=color.red, style=plot.style_linebr, linewidth=2)
//plot(triangleBottom, title="Triangle Bottom", color=color.green, style=plot.style_linebr, linewidth=2)
plot(inTradeSetup1 ? trailingStop1 : na, color=color.red, title="Trailing Stop - Setup 1", linewidth=2,style=plot.style_linebr)
plot(inTradeSetup2 ? trailingStop2 : na, color=color.blue, title="Trailing Stop - Setup 2", linewidth=2,style=plot.style_linebr)

plotshape(enterSetup1, title="Triangle Breakout Entry", location=location.belowbar, color=color.green, style=shape.triangleup, size=size.small)
plotshape(enterSetup2, title="Volume Confirmed Entry", location=location.belowbar, color=color.blue, style=shape.circle, size=size.small)

// === Alerts ===
alertcondition(enterSetup1, title="Setup 1 Buy", message="Golden Triangle Breakout (Setup 1) - BUY")
alertcondition(enterSetup2, title="Setup 2 Buy", message="Volume + Price Confirmation (Setup 2) - BUY")

// === Background highlight during trades ===
bgcolor(inTradeSetup1 or inTradeSetup2 ? color.new(color.green, 85) : na, title="In-Trade Highlight")


// === Weekly Fibonacci Pivot Levels (R3 / S3) ===
weeklyHigh = request.security(syminfo.tickerid, "W", high)
weeklyLow = request.security(syminfo.tickerid, "W", low)
weeklyClose = request.security(syminfo.tickerid, "W", close)

weeklyPivot = (weeklyHigh + weeklyLow + weeklyClose) / 3
weeklyRange = weeklyHigh - weeklyLow
fibR3 = weeklyPivot + 1.000 * weeklyRange
fibS3 = weeklyPivot - 1.000 * weeklyRange

// === Plot R3 and S3 ===
plot(fibR3, title="Weekly Fib R3", color=color.fuchsia, linewidth=2, style=plot.style_circles)
plot(fibS3, title="Weekly Fib S3", color=color.teal, linewidth=2, style=plot.style_circles)
// === Weekly Fibonacci Pivot Levels (R3 / S3) ===