19.01.2022
0
2
105
100

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);

		}
	}
}

0 Yorum