Merhabalar,
İndikatör ek olarak mevcuttur.
Lütfen inceleyiniz.
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:=10;
coeff:=3;
AP:=mov(c,Length,e);
OFFSET:=coeff*ATR(period);
STR:=AP+OFFSET;
STS:=AP-OFFSET;
FUB:=IF(STR<PREV OR REF(C,-1)>PREV,STR,PREV);
FLB:=IF(STS>PREV OR REF(C,-1)<PREV,STS,PREV);
ST:=IF(PREV=REF(FUB,-1) AND C<FUB,FUB,IF(PREV=REF(FUB,-1) AND C>FUB,FLB,IF(PREV=REF(FLB,-1) AND C>FLB,FLB,IF(PREV=REF(FLB,-1) AND C<FLB,FUB,fub))));
ST
*/
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("SuperTrendMovingAverage", IndicatorDrawingArea.OnDataSeries)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"ST(0,1)"
})]
public class SuperTrendMovingAverage : 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(3)]
public int Lenght
{
get; set;
}
[DefaultValue(10)]
public int Period
{
get; set;
}
[DefaultValue(3)]
public decimal Coeff
{
get; set;
}
ATR atr;
MOV mov;
Dictionary<int, decimal> FUBDict = new Dictionary<int, decimal>();
Dictionary<int, decimal> FLBDict = new Dictionary<int, decimal>();
Dictionary<int, decimal> STDict = new Dictionary<int, decimal>();
public override void OnInit()
{
atr = ATRIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period);
mov = MOVIndicator(Symbol, SymbolPeriod, OHLCType.Close, Lenght, MovMethod.Exponential);
}
decimal AP, OFFSET, STR, STS;
decimal prevFub, prevFlb, prevSt, fub, flb;
public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
{
if (currentBar < Period)
{
FUBDict[currentBar] = 0;
FLBDict[currentBar] = 0;
STDict[currentBar] = 0;
SetLine(0, currentBar, 0);
return ;
}
var close = Instrument.SymbolBarData.Close[currentBar];
var prevClose = Instrument.SymbolBarData.Close[currentBar -1];
AP = mov.CurrentValue;
OFFSET = Coeff * atr.CurrentValue;
STR = AP + OFFSET;
STS = AP - OFFSET;
if (FUBDict.ContainsKey(currentBar -1))
{
prevFub = FUBDict[currentBar -1];
prevFlb = FLBDict[currentBar -1];
prevSt = STDict[currentBar -1];
FUBDict[currentBar] = STR<prevFub || prevClose>prevFub ? STR:prevFub;
FLBDict[currentBar] = STS>prevFlb || prevClose<prevFlb ? STS:prevFlb;
fub = FUBDict[currentBar];
flb = FLBDict[currentBar];
STDict[currentBar] = prevSt == prevFub && close<fub ? fub : (prevSt == prevFub && close>fub ? flb : (prevSt == prevFlb && close>flb ? flb : fub));
SetLine(currentBar, STDict[currentBar]);
}else
{
SetLine(currentBar, 0);
}
}
}
}
İyi çalışmalar.