Warning! This section will be deprecated on February 1st 2025. Please move all your Indicators to the cTrader Store catalogue.
Description
Insepired by KivancOzbilgic from TradingView.
I'm not 100% sure the algorithm is the same as the original version of KivancOzbilgic. So feel free to suggest improvements to the code.
using System;
using cAlgo.API;
using cAlgo.API.Indicators;
namespace cAlgo.Indicators
{
[Indicator(IsOverlay = true, AccessRights = AccessRights.None)]
public class PMAXIndicator : Indicator
{
// INPUT
[Parameter("Period", Group = "Supertrend", DefaultValue = 10, MinValue = 1, Step = 1)]
public int Period { get; set; }
[Parameter("Multiplier", Group = "Supertrend", DefaultValue = 3.0, MinValue = 0.1, Step = 0.1)]
public double Multiplier { get; set; }
[Parameter("Change ATR Calculation?", Group = "Supertrend", DefaultValue = true)]
public bool SmoothedAtr { get; set; }
[Parameter("MA Type", Group = "Moving Average")]
public MovingAverageType MAType { get; set; }
[Parameter("MA Source", Group = "Moving Average")]
public DataSeries SourceSeries { get; set; }
[Parameter("MA Lenght", Group = "Moving Average", DefaultValue = 10, MinValue = 2, Step = 20)]
public int MALenght { get; set; }
// OUTPUT
[Output("LowerBand", LineColor = "green", PlotType = PlotType.DiscontinuousLine, Thickness = 3)]
public IndicatorDataSeries LowerBand { get; set; }
[Output("UpperBand", LineColor = "red", PlotType = PlotType.DiscontinuousLine, Thickness = 3)]
public IndicatorDataSeries UpperBand { get; set; }
[Output("MA Line", LineColor = "yellow", PlotType = PlotType.Points, Thickness = 1)]
public IndicatorDataSeries MALine { get; set; }
private IndicatorDataSeries _upperBandBuffer;
private IndicatorDataSeries _lowerBandBuffer;
private IndicatorDataSeries _trend;
private AverageTrueRange _averageTrueRange;
private MovingAverage _ma;
private bool _changeofTrend;
protected override void Initialize()
{
_trend = CreateDataSeries();
_upperBandBuffer = CreateDataSeries();
_lowerBandBuffer = CreateDataSeries();
_averageTrueRange = Indicators.AverageTrueRange(Period, SmoothedAtr ? MovingAverageType.WilderSmoothing : MovingAverageType.Exponential);
_ma = Indicators.MovingAverage(SourceSeries, MALenght, MAType);
}
public override void Calculate(int index)
{
LowerBand[index] = double.NaN;
UpperBand[index] = double.NaN;
MALine[index] = _ma.Result[index];
double atr = _averageTrueRange.Result[index];
_upperBandBuffer[index] = MALine[index] + Multiplier * atr;
_lowerBandBuffer[index] = MALine[index] - Multiplier * atr;
if (index < 1)
{
_trend[index] = 1;
return;
}
if (MALine[index] > _upperBandBuffer[index - 1])
{
_trend[index] = 1;
if (_trend[index - 1] == -1)
_changeofTrend = true;
}
else if (MALine[index] < _lowerBandBuffer[index - 1])
{
_trend[index] = -1;
if (_trend[index - 1] == 1)
_changeofTrend = true;
}
else if (_trend[index - 1] == 1)
{
_trend[index] = 1;
_changeofTrend = false;
}
else if (_trend[index - 1] == -1)
{
_trend[index] = -1;
_changeofTrend = false;
}
if (_trend[index] < 0 && _trend[index - 1] > 0)
_upperBandBuffer[index] = MALine[index] + (Multiplier * atr);
else if (_trend[index] < 0 && _upperBandBuffer[index] > _upperBandBuffer[index - 1])
_upperBandBuffer[index] = _upperBandBuffer[index - 1];
if (_trend[index] > 0 && _trend[index - 1] < 0)
_lowerBandBuffer[index] = MALine[index] - (Multiplier * atr);
else if (_trend[index] > 0 && _lowerBandBuffer[index] < _lowerBandBuffer[index - 1])
_lowerBandBuffer[index] = _lowerBandBuffer[index - 1];
// Draw Bands
if (_trend[index] == 1)
{
LowerBand[index] = _lowerBandBuffer[index];
if (_changeofTrend)
{
LowerBand[index - 1] = UpperBand[index - 1];
_changeofTrend = false;
}
}
else if (_trend[index] == -1)
{
UpperBand[index] = _upperBandBuffer[index];
if (_changeofTrend)
{
UpperBand[index - 1] = LowerBand[index - 1];
_changeofTrend = false;
}
}
}
}
}
MA
matheuscabralkk
Joined on 14.07.2021
- Distribution: Free
- Language: C#
- Trading platform: cTrader Automate
- File name: PMAX Indicator.algo
- Rating: 0
- Installs: 1374
- Modified: 20/07/2022 17:00
Note that publishing copyrighted material is strictly prohibited. If you believe there is copyrighted material in this section, please use the Copyright Infringement Notification form to submit a claim.
Comments
Log in to add a comment.
nice