Hareketli ortalama ve bar sayısını kullanarak hesaplamalar yapar.
Ana çizgi ve bunun bir bar ötelenmiş hali olan 2. Bir çizgi çizer.
Bu 2 çizginin kesişmesine göre AL-SAT sinyalleri üretir.
COG çizgisinin prev COG çizgisini yukarı kesmesi AL, aşağı kesmesi ise SAT sinyali olarak yorumlanır.
AL-SAT stratejisini algoritma sihirbazı ile kolayca oluşturabilirsiniz.
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:=input("Period",1,500,10);
num:=mov(c,period,w)*(period*(period+1)/2);
den:=sum(c,period);
CG:=num/den;
CG;
ref(cg,-1)
*/
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("COGKripex", IndicatorDrawingArea.NewWindow)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"CG(0)", "prevCG"
})]
public class COGKripex : 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 Period
{
get; set;
}
[DefaultValue(MovMethod.W)]
public MovMethod MovMethod
{
get; set;
}
SMA sma;
MOV mov;
public sealed override void OnInit()
{
sma = SMAIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period);
mov = MOVIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period, MovMethod);
}
public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
{
var barDataModel = GetBarData();
if (currentBar < Period)
{
SetLine(0, currentBar, 0);
SetLine(1, currentBar, 0);
return ;
}
var num = mov.CurrentValue * (Period * (Period + 1) / 2);
var den = sma.Value[0][sma.CurrentIndex]*10;
var cg=den!=0?num/den:0;
var prevCg=Value[0][currentBar-1];
SetLine(0, currentBar, cg);
SetLine(1, currentBar, prevCg);
}
}
}