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