MOST ve Directional Indicator verileri kullanılır.
Directional Indicator, teknik analizde en iyi trend gösteren indikatörlerden biridir.
DI+ yüzdesel olarak yukarı hareketi, DI– ise aşağı hareket oranını temsil eder.
Strateji, DI+ değeri DI–’nın üzerine kırdığında veya MOST’un hareketli ortalama komponenti MOST’un üzerine kırdığında alış,
bu koşullardan herhangi biri tersine döndüğünde ise satış emri gönderir.

using System;
using System.Collections.Generic;
using System.Linq;
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;
using Matriks.Data.Tick;
using Matriks.Enumeration;
using Matriks.IntermediaryInstitutionAnalysis.Enums;
using Newtonsoft.Json;


namespace Matriks.Lean.Algotrader
{
    public class MostDICross : MatriksAlgo
    {
        // Strateji çalıştırılırken kullanacağımız parametreler. Eğer sembolle ilgili bir parametre ise,
        // "SymbolParameter" ile, değilse "Parameter" ile tanımlama yaparız. Parantez içindeki değerler default değerleridir.

        [SymbolParameter("GARAN")]
        public string Symbol;

        [Parameter(SymbolPeriod.Min60)]
        public SymbolPeriod SymbolPeriod;

        [Parameter(100)]
        public decimal BuyOrderQuantity;

        [Parameter(100)]
        public decimal SellOrderQuantity;

        [Parameter(14)]
        public int DIPeriod;

        [Parameter(4)]
        public int MOSTPeriod;

        [Parameter(1)]
        public decimal Percentage;

        DI di;
        MOST most;
         
        public override void OnInit()
        {
            di = DIIndicator(Symbol, SymbolPeriod, OHLCType.Close, DIPeriod);
            most = MOSTIndicator(Symbol, SymbolPeriod, OHLCType.Close, MOSTPeriod, Percentage, MovMethod.Exponential);
            AddSymbol(Symbol, SymbolPeriod);

            // Algoritmanın kalıcı veya geçici sinyal ile çalışıp çalışmayacağını belirleyen fonksiyondur.
            // true geçerseniz algoritma sadece yeni bar açılışlarında çalışır, bu fonksiyonu çağırmazsanız veya false geçerseniz her işlem olduğunda algoritma tetiklenir.
            WorkWithPermanentSignal(true);

            //Eger backtestte emri bir al bir sat seklinde gonderilmesi isteniyor bu true set edilir. 
            //Alttaki satırı silerek veya false geçerek emirlerin sirayla gönderilmesini engelleyebilirsiniz. 
            SendOrderSequential(true);
        }


        /// <summary>
        /// Eklenen sembollerin bardata'ları ve indikatorler güncellendikçe bu fonksiyon tetiklenir. 
        /// </summary>
        /// <param name="barData">Bardata ve hesaplanan gerçekleşen işleme ait detaylar</param>
        public override void OnDataUpdate(BarDataEventArgs barData)
        {
            Debug("most.ExMOV.CurrentValue " + Math.Round(most.ExMOV.CurrentValue, 2));
            Debug("most.CurrentValue " + Math.Round(most.CurrentValue, 2));
            Debug("di.Pdi.CurrentValue " + Math.Round(di.Pdi.CurrentValue, 2) + " di.Mdi.CurrentValue " + Math.Round(di.Mdi.CurrentValue, 2));
            if (CrossAbove(di.Pdi, di.Mdi) || CrossAbove(most.ExMOV, most))
            {
                SendMarketOrder(Symbol, BuyOrderQuantity, (OrderSide.Buy));
                Debug("Alış emri gönderildi.");
            }
            if (CrossBelow(di.Pdi, di.Mdi) || CrossBelow(most.ExMOV, most))
            {
                SendMarketOrder(Symbol, SellOrderQuantity, (OrderSide.Sell));
                Debug("Satış emri gönderildi.");
            }
        }

		/// <summary>
		/// Strateji durdurulduğunda bu fonksiyon tetiklenir.
		/// </summary>
		public override void OnStopped()
		{
		}
    }
}