Category Volatility  Published on 17/05/2024

Volume Pulse V.2.1 =)

Description

Just to say hi to those who blocked me, and sent a bomb =)

Is the candle True or False Volume ? Now you know =) 

Enjoy for Free =) 

Previous account here : https://ctrader.com/users/profile/70920
Contact telegram :  https://t.me/nimi012 


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using cAlgo.API;
using cAlgo.API.Collections;
using cAlgo.API.Indicators;
using cAlgo.API.Internals;

namespace cAlgo.Indicators
{
    [Indicator(IsOverlay = false, TimeZone = TimeZones.UTC, AccessRights = AccessRights.None)]
    public class VolumePulsev21 : Indicator
    {
        [Parameter("Lower Timeframe Volume Cumulation", DefaultValue = "Minute")]
        public TimeFrame TF { get; set; }

        [Parameter("Period", DefaultValue = 1)]
        public int Period { get; set; }
        [Parameter("Lower Timeframe Volume Cumulation", DefaultValue = MovingAverageType.Weighted)]
        public MovingAverageType MaType { get; set; }

        [Output("Volume Delta Plus", LineColor = "Lime")]
        public IndicatorDataSeries VolumeDeltaPlus2 { get; set; }
        [Output("Volume Delta Min ", LineColor = "Red")]
        public IndicatorDataSeries VolumeDeltaMin2 { get; set; }

        [Output("Histo Plus", LineColor = "Lime", PlotType = PlotType.Histogram)]
        public IndicatorDataSeries HistoUp { get; set; }
        [Output("Histo Min ", LineColor = "Red", PlotType = PlotType.Histogram)]
        public IndicatorDataSeries HistoDown { get; set; }

        private Bars barsTick;
        private DateTime prevBars;
        private MovingAverage smoothvolumPlus, smoothvolumMinus;
        private IndicatorDataSeries resvolumPlus, resolumMinus;
        private IndicatorDataSeries VolumeDeltaPlus, VolumeDeltaMin;

        private double barsCount;
        private int pct = 0;
        private int nbBarsLast;
        private bool isLastB;

        protected override void Initialize()
        {
            barsTick = MarketData.GetBars(TF);
            if (!IsBacktesting)
            {
                while (barsTick.OpenTimes[0] > Bars.OpenTimes[0])
                    barsTick.LoadMoreHistory();
            }
            prevBars = Bars.OpenTimes.Last(0);
            resvolumPlus = CreateDataSeries();
            resolumMinus = CreateDataSeries();

            VolumeDeltaPlus = CreateDataSeries();
            VolumeDeltaMin = CreateDataSeries();


            smoothvolumPlus = Indicators.MovingAverage(resvolumPlus, Period, MaType);
            smoothvolumMinus = Indicators.MovingAverage(resolumMinus, Period, MaType);
            pct = 0;
            barsCount = Bars.Count;
            nbBarsLast = 0;
            isLastB = false;
            Bars.BarOpened += Bars_BarOpened;
            barsTick.BarOpened += BarsTick_BarOpened;
        }

        private void BarsTick_BarOpened(BarOpenedEventArgs obj)
        {
            nbBarsLast++;
            isLastB = true;
        }

        private void Bars_BarOpened(BarOpenedEventArgs obj)
        {
            nbBarsLast = 0;
            isLastB = true;

        }
        public override void Calculate(int index)
        {
            barsCount = Bars.Count;
            if (index == 0) return;

            var index1 = barsTick.OpenTimes.GetIndexByTime(Bars.OpenTimes[index]);
            if (Bars.OpenTimes.Last(0) != prevBars || isLastB)
            {
                double deltaVolumePlus = 0.0;
                double deltaVolumeMin = 0.0;
                double countDeltaPlus = 0;
                double countDeltaMinus = 0;
                int nbBars = 0;
                DateTime BarsTick = barsTick.OpenTimes[index1];
                if (!isLastB)
                    for (int i = 0; Bars.OpenTimes[index - 1] < BarsTick; i++)
                    {
                        BarsTick = barsTick.OpenTimes[index1 - i];
                        nbBars++;
                    }
                for (int i = 0; i < (isLastB ? nbBarsLast : nbBars); i++)
                {
                    double prevClose = barsTick.OpenPrices[index1 - i];
                    double currentClose = barsTick.ClosePrices[index1 - i];
                    double volume = barsTick.TickVolumes[index1 - i];
                    double pipsizeUp = Math.Abs(barsTick.ClosePrices[index1 - i] - barsTick.LowPrices[index1 - i]) / (barsTick.HighPrices[index1 - i] - barsTick.LowPrices[index1 - i]);
                    double pipsizeDown = Math.Abs(barsTick.HighPrices[index1 - i] - barsTick.ClosePrices[index1 - i]) / (barsTick.HighPrices[index1 - i] - barsTick.LowPrices[index1 - i]);

                    if (currentClose > prevClose)
                    {
                        deltaVolumePlus = deltaVolumePlus + volume * pipsizeUp;
                        //countDeltaPlus++;
                    }
                    else if (currentClose < prevClose)
                    {
                        deltaVolumeMin = deltaVolumeMin + volume * pipsizeDown;
                        //countDeltaMinus++;
                    }
                }

                resvolumPlus[index] = deltaVolumePlus / Bars.TickVolumes.Last(0);
                resolumMinus[index] = deltaVolumeMin / Bars.TickVolumes.Last(0);

                VolumeDeltaPlus[index] = smoothvolumPlus.Result.Last(0);
                VolumeDeltaMin[index] = smoothvolumMinus.Result.Last(0); ;

                VolumeDeltaPlus2[index] = VolumeDeltaPlus[index] / (VolumeDeltaMin[index] + VolumeDeltaPlus[index]);
                VolumeDeltaMin2[index] = VolumeDeltaMin[index] / (VolumeDeltaMin[index] + VolumeDeltaPlus[index]);

            }

            if (Bars.ClosePrices[index] > Bars.OpenPrices[index])
            {
                Chart.RemoveObject("VolumeDowntxt" + index);
                Chart.RemoveObject("VolumeDown" + index);

                Chart.DrawTrendLine("VolumeUp" + index, index, (Bars.ClosePrices[index] - Bars.OpenPrices[index]) * (VolumeDeltaPlus[index] / (VolumeDeltaMin[index] + VolumeDeltaPlus[index])) + Bars.OpenPrices[index], index, Bars.OpenPrices[index], Color.Lime, 5);
                Chart.DrawText("VolumeUptxt" + index, ((VolumeDeltaPlus[index] / (VolumeDeltaMin[index] + VolumeDeltaPlus[index])) * 100).ToString("F0"), index, Bars.HighPrices[index] + 5 * Symbol.PipSize, Color.Lime);

            }
            else if (Bars.ClosePrices[index] < Bars.OpenPrices[index])
            {
                Chart.RemoveObject("VolumeUptxt" + index);
                Chart.RemoveObject("VolumeUp" + index);

                Chart.DrawTrendLine("VolumeDown" + index, index, Bars.OpenPrices[index] - (Bars.OpenPrices[index] - Bars.ClosePrices[index]) * (VolumeDeltaMin[index] / (VolumeDeltaPlus[index] + VolumeDeltaMin[index])), index, Bars.OpenPrices[index], Color.Red, 5);
                Chart.DrawText("VolumeDowntxt" + index, ((VolumeDeltaMin[index] / (VolumeDeltaMin[index] + VolumeDeltaPlus[index])) * 100).ToString("F0"), index, Bars.LowPrices[index] - 5 * Symbol.PipSize, Color.Red);

            }

            if (!isLastB)
                prevBars = Bars.OpenTimes.Last(0);

            double test = index / barsCount * 100;

            if (pct < test + 0.1 && pct < 105)
            {
                Print("Load : " + test.ToString("F0") + " %");
                pct += 10;
            }
        }
    }
}




YE
YesOrNot2

Joined on 17.05.2024

  • Distribution: Free
  • Language: C#
  • Trading platform: cTrader Automate
  • File name: Volume Pulse v2.1 .algo
  • Rating: 5
  • Installs: 736
  • Modified: 17/05/2024 12:35
Comments
Log in to add a comment.
YE
YesOrNot2 · 7 months ago

Thank you for the support!

sherlock828r If needed, I am available on Telegram. =)

SH
sherlock828r · 7 months ago

Your conclusions are probably not accurate. This may be why someone was bitterly jealous of your good work in producing accurate indicator readings. I was unable to install your Volume Pulse V.2.1 indicator in my CTrader, I received a message that you are blocked. This is probably all unfortunate, I'm wasting my time working in CTrader. I do not exclude that for clarification you need to contact the support service of the administration of this site SPOWARE CTRADER. Sincerely. I wish you a speedy exit from self-isolation. And I apologize for the inaccurate translation. I also express my gratitude to you for your work in creating indicators.

 

JI
jim.tollan · 8 months ago

whoever got you blocked is obviously a complete w*nker as everything you've given is given generously and for free. 

welcome back!!