14.01.2022
0
1
104
100

SmoothedRSI İndikatörü

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;
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("SmoothedRSIKripex", IndicatorDrawingArea.NewWindow)]
	//Indikatörün çizgilerinin isimleri
	[IndicatorLineInformationAttribute(new []
		{
			"SmoothedRSI(0)"
		}, new []
		{
			"#00CCFF"
		}, new []
		{
			false
		}, new []
		{
			0
		}, new []
		{
			2
		}
	)]

	public class SmoothedRSIKripex : 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(10)]
		public int Length
		{
			get; set;
		}

		public sealed override void OnInit()
		{
		}

		decimal xValue, cu23, cd23;
		Dictionary<int, decimal> xValueList = new Dictionary<int, decimal>();
		Dictionary<int, decimal> cu23List = new Dictionary<int, decimal>();
		Dictionary<int, decimal> cd23List = new Dictionary<int, decimal>();

		public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
		{			
			xValueList[currentBar] = Instrument.SymbolBarData.Close.ContainsKey(currentBar -3)?(Instrument.SymbolBarData.Close[currentBar] + 2 * Instrument.SymbolBarData.Close[currentBar -1] + 2 * Instrument.SymbolBarData.Close[currentBar -2] + Instrument.SymbolBarData.Close[currentBar -3]) / 6:0;

			if (currentBar < Period)
			{
				SetLine(0, currentBar, 0);
				return ;
			}

			if (xValueList.ContainsKey(currentBar -1))
			{
				cu23List[currentBar] = xValueList[currentBar] >xValueList[currentBar -1]?xValueList[currentBar] - xValueList[currentBar -1]:0;
				cd23List[currentBar] = xValueList[currentBar] <xValueList[currentBar -1]?xValueList[currentBar -1] - xValueList[currentBar]:0;
			}

			cu23 = cu23List.Values.Skip(cu23List.Count - Length).Sum();
			cd23 = cd23List.Values.Skip(cd23List.Count - Length).Sum();

			var nRes = (cu23 + cd23) != 0? cu23 / (cu23 + cd23) :0;

			SetLine(currentBar, nRes);

		}
	}
}

0 Yorum