133 lines
4.1 KiB
C#
133 lines
4.1 KiB
C#
#region Using declarations
|
|
using NinjaTrader.Gui;
|
|
using NinjaTrader.Gui.Chart;
|
|
using System;
|
|
using System.ComponentModel.DataAnnotations;
|
|
using System.Windows.Media;
|
|
#endregion
|
|
|
|
namespace NinjaTrader.NinjaScript.Indicators
|
|
{
|
|
[CategoryOrder("SuperSmoother", 1)]
|
|
[CategoryOrder("Plots", 2)]
|
|
public class SuperSmoother : Indicator
|
|
{
|
|
private double a;
|
|
private double b;
|
|
private double c1;
|
|
private double c2;
|
|
private double c3;
|
|
|
|
protected override void OnStateChange()
|
|
{
|
|
if (State == State.SetDefaults)
|
|
{
|
|
Description = @"Credit to John F. Ehlers";
|
|
Name = "SuperSmoother";
|
|
Calculate = Calculate.OnPriceChange;
|
|
IsOverlay = true;
|
|
DisplayInDataBox = true;
|
|
DrawOnPricePanel = true;
|
|
DrawHorizontalGridLines = true;
|
|
DrawVerticalGridLines = true;
|
|
PaintPriceMarkers = true;
|
|
ScaleJustification = ScaleJustification.Right;
|
|
IsSuspendedWhileInactive = true;
|
|
Period = 10;
|
|
AddPlot(new Stroke(Brushes.Yellow, DashStyleHelper.Solid, 2), PlotStyle.Line, "SuperSmoother");
|
|
}
|
|
else if (State == State.Configure)
|
|
{
|
|
a = Math.Exp(-1.414 * Math.PI / Period);
|
|
b = 2 * a * Math.Cos(1.414 * 180 / Period);
|
|
c2 = b;
|
|
c3 = -a * a;
|
|
c1 = 1 - c2 - c3;
|
|
}
|
|
else if (State == State.Historical)
|
|
{
|
|
SetZOrder(-1); // Display behind bars on chart.
|
|
}
|
|
}
|
|
|
|
protected override void OnBarUpdate()
|
|
{
|
|
if (CurrentBar < 3) // Need at least 3 bars.
|
|
{
|
|
Value[0] = Input[0];
|
|
return;
|
|
}
|
|
|
|
Value[0] = c1 * (Input[0] + Input[1]) / 2 + c2 * Value[1] + c3 * Value[2];
|
|
}
|
|
|
|
public override string DisplayName
|
|
{
|
|
get { return Name; }
|
|
}
|
|
|
|
#region Properties
|
|
[Range(1, int.MaxValue), NinjaScriptProperty]
|
|
[Display(Name = "Period", Order = 1, GroupName = "SuperSmoother")]
|
|
public int Period { get; set; }
|
|
#endregion
|
|
}
|
|
}
|
|
|
|
#region NinjaScript generated code. Neither change nor remove.
|
|
|
|
namespace NinjaTrader.NinjaScript.Indicators
|
|
{
|
|
public partial class Indicator : NinjaTrader.Gui.NinjaScript.IndicatorRenderBase
|
|
{
|
|
private SuperSmoother[] cacheSuperSmoother;
|
|
public SuperSmoother SuperSmoother(int period)
|
|
{
|
|
return SuperSmoother(Input, period);
|
|
}
|
|
|
|
public SuperSmoother SuperSmoother(ISeries<double> input, int period)
|
|
{
|
|
if (cacheSuperSmoother != null)
|
|
for (int idx = 0; idx < cacheSuperSmoother.Length; idx++)
|
|
if (cacheSuperSmoother[idx] != null && cacheSuperSmoother[idx].Period == period && cacheSuperSmoother[idx].EqualsInput(input))
|
|
return cacheSuperSmoother[idx];
|
|
return CacheIndicator<SuperSmoother>(new SuperSmoother(){ Period = period }, input, ref cacheSuperSmoother);
|
|
}
|
|
}
|
|
}
|
|
|
|
namespace NinjaTrader.NinjaScript.MarketAnalyzerColumns
|
|
{
|
|
public partial class MarketAnalyzerColumn : MarketAnalyzerColumnBase
|
|
{
|
|
public Indicators.SuperSmoother SuperSmoother(int period)
|
|
{
|
|
return indicator.SuperSmoother(Input, period);
|
|
}
|
|
|
|
public Indicators.SuperSmoother SuperSmoother(ISeries<double> input , int period)
|
|
{
|
|
return indicator.SuperSmoother(input, period);
|
|
}
|
|
}
|
|
}
|
|
|
|
namespace NinjaTrader.NinjaScript.Strategies
|
|
{
|
|
public partial class Strategy : NinjaTrader.Gui.NinjaScript.StrategyRenderBase
|
|
{
|
|
public Indicators.SuperSmoother SuperSmoother(int period)
|
|
{
|
|
return indicator.SuperSmoother(Input, period);
|
|
}
|
|
|
|
public Indicators.SuperSmoother SuperSmoother(ISeries<double> input , int period)
|
|
{
|
|
return indicator.SuperSmoother(input, period);
|
|
}
|
|
}
|
|
}
|
|
|
|
#endregion
|