19.01.2022
0
2
175
100

Sniper

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;

/*
	pds1:=10; 
	pds2:=2;
	SNP:=Mov(Mov(C-Ref(C,-1),pds1,e),pds2,e)/Mov(Mov(Abs(C-Ref(C,-1)),pds1,e),pds2,e)*500;
	MV:=MOV(SNP,9,S);
	SNP;MV
	::0
*/

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("SniperKripex", IndicatorDrawingArea.NewWindow)]
	//Indikatörün çizgilerinin isimleri
	[IndicatorLineInformationAttribute(new []
		{
			"SNP", "MV"
		})]

	public class SniperKripex : 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 EmaUzunPeriod
		{
			get; set;
		}

		[DefaultValue(2)]
		public int EmaKisaPeriod
		{
			get; set;
		}

		[DefaultValue(9)]
		public int SmaPeriod
		{
			get; set;
		}
		SMA sma;

		EMA ema1, ema2;
		EMA ema3, ema4;

		public sealed override void OnInit()
		{
			sma = new SMA(SmaPeriod);

			ema1 = new EMA(EmaKisaPeriod);
			ema2 = new EMA(EmaUzunPeriod);
			

			ema3 = new EMA(EmaKisaPeriod);
			ema4 = new EMA(EmaUzunPeriod);

			DrawHorizantal(0);
		}

		decimal close, prevClose, snp, mv;

		public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
		{
			if (currentBar < EmaUzunPeriod)
			{
				SetLine(0, currentBar, 0);
				SetLine(1, currentBar, 0);
				return ;
			}

			/*
				pds1:=10; 
				pds2:=2;
				SNP:=Mov(Mov(C-Ref(C,-1),pds1,e),pds2,e)/Mov(Mov(Abs(C-Ref(C,-1)),pds1,e),pds2,e)*500;
				MV:=MOV(SNP,9,S);
				SNP;MV
				::0
			*/

			close = Instrument.SymbolBarData.Close[currentBar];
			
			prevClose = Instrument.SymbolBarData.Close.ContainsKey(currentBar-1)?Instrument.SymbolBarData.Close[currentBar -1]:0;			

			// Mov(C-Ref(C,-1),pds1,e)
			ema2.Update(close - prevClose, currentBar, barDateTime);
			// Mov(Mov(C-Ref(C,-1),pds1,e),pds2,e)
			ema1.Update(ema2.CurrentValue, currentBar, barDateTime);

			//Mov(Abs(C-Ref(C,-1)),pds1,e)
			ema4.Update(Math.Abs(close - prevClose), currentBar, barDateTime);
			
			// Mov(Mov(Abs(C-Ref(C,-1)),pds1,e),pds2,e)
			ema3.Update(ema4.CurrentValue, currentBar, barDateTime);
			
			snp = ema3.CurrentValue != 0 ? ema1.CurrentValue / ema3.CurrentValue * 500:0;			

			sma.Update(snp, currentBar, barDateTime);

			mv = sma.CurrentValue;

			SetLine(0, currentBar, snp);
			SetLine(1, currentBar, mv);

		}
	}
}

0 Yorum