25.01.2022
0
2
94
100

Alma

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("ALMAKripex", IndicatorDrawingArea.OnDataSeries)]
	//Indikatörün çizgilerinin isimleri
	[IndicatorLineInformationAttribute(new []
		{
			"ALMA(0,1)"
		})]

	public class ALMAKripex : 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(6)]
			public decimal Sigma
		{
			get; set;
		}
		
		[DefaultValue(0.85)]
			public decimal Offset
		{
			get; set;
		}
		
		double bolen,kok;
		
		Dictionary<int,decimal> wList=new Dictionary<int,decimal>();
		Dictionary<int,decimal> sList=new Dictionary<int,decimal>();

		public sealed override void OnInit()
		{
			kok=Math.Round((double)Offset*8-0.5,0);
			bolen=Sigma!=0?(2*Math.Pow((double)(9/Sigma),2)):0;			
			
			for(var i=0; i<=8; i++){
				wList[i]=bolen!=0?(decimal)Math.Exp(-1*Math.Pow(i-kok,2)/bolen):0;
			}
		}

		public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
		{			
			if(!Instrument.SymbolBarData.Close.ContainsKey(currentBar-8)){
				SetLine(currentBar, 0);
				return;
			}
			
			var wSon=wList.LastOrDefault().Value;
			var close=Instrument.SymbolBarData.Close[currentBar];
			
			for(var i=0; i<=7; i++){
				sList[i]=wList[i]*Instrument.SymbolBarData.Close[currentBar-8+i];
			}			
			
			var alma=wList.Values.Sum()>0?(sList.Values.Sum()+wSon*close)/wList.Values.Sum():close;
			
			SetLine(currentBar, alma);
		}
	}
}

0 Yorum