KDJ-KDJ Indicator
using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using Matriks.Data.Identifiers;
using Matriks.Data.Symbol;
using Matriks.Engines;
using Matriks.Indicators;
using Matriks.Symbols;
using Matriks.AlgoTrader;
using Matriks.Trader.Core;
using Matriks.Trader.Core.Fields;
using Matriks.Trader.Core.TraderModels;
using Matriks.Lean.Algotrader.AlgoBase;
using Matriks.Lean.Algotrader.Models;
using Matriks.Lean.Algotrader.Trading;
/*
period:=input("Period",1,500,9);
signal:=input("Signal",1,500,3);
pK:=(STOFK(Period,1173,ZL)+(signal-1)*Prev)/signal;
pD:=(pK+(signal-1)*Prev)/signal;
pJ:=3*pK-2*pD;
pK;
pD;
pJ
*/
namespace Matriks.Lean.Algotrader
{
//Ilk parametre indikatörün adı, sınıfın adıyla aynı olmalıdır.
//Ikinci parametre indikatörün Dataserisinin üzerine mi yeni pencereye mi ekleneceğini belirtir. Yeni pencere için ->IndicatorDrawingArea.NewWindow , Data Serisi için IndicatorDrawingArea.OnDataSeries
[IndicatorInformationAttribute("KDJKripex", IndicatorDrawingArea.NewWindow)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"K", "D", "J"
})]
public class KDJKripex : MatriksIndicator
{
//Indicator opsiyon panelinde değerleri değiştirebildiğimiz parametreler. Int, Bool, Decimal ve Enum değerleri alabilir.Tüm değişken tiplerini DefaultValue ile tanımlarız.
[DefaultValue(9)]
public int Period
{
get; set;
}
[DefaultValue(3)]
public decimal Signal
{
get; set;
}
StochasticFast stochasticFast;
public sealed override void OnInit()
{
stochasticFast = StochasticFastIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period, 1173, MovMethod.ZL);
}
decimal k = 0, d = 0, j = 0;
public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
{
if (currentBar < Period)
{
SetLine(0, currentBar, 0);
SetLine(1, currentBar, 0);
SetLine(2, currentBar, 0);
return ;
}
k =Signal!=0?(stochasticFast.StochasticFastK.CurrentValue + (Signal -1) * k) / Signal:0;
d =Signal!=0? (k + (Signal -1) * d) / Signal:0;
j = 3 * k -2 * d;
SetLine(0, currentBar, k);
SetLine(1, currentBar, d);
SetLine(2, currentBar, j);
}
}
}