İki Üssel Hareketli Ortalamanın kesişimlerine göre sinyal üretmektedir. Sembol, Periyot, Ortalama Periyotları ve Alış/Satış emir miktarları strateji parametre ekranından değiştirilebilmektedir. Strateji bar data kapanışıyla tetiklenecektir. Strateji içinde kullanılan “WorkWithPermanentSignal(true)” false olarak değiştirildiğinde geçici sinyal ile çalışacaktır. Al/Sat sinyalleri sıralı olarak çalışmaktadır. Strateji içinde kullanılan “SendOrderSequential(true)” false olarak değiştirildiğinde al/sat sinyalleri sıralı olmaksızın her sinyal oluştuğunda çalışacaktır. Bu stratejide kısa vadeli üssel ortalama, uzun vadeli ortalamayı yukarı yönlü kestiğinde Alış, aşağı yönlü kestiğinde satış emri gönderilir.
Emirler piyasa fiyatından gönderilecektir. Emir gönderimleri ile birlikte strateji raporlarında Debug sekmesine “Alış Emri Gönderildi” ve “Satış Emri Gönderildi” ifadesi yazdırılmaktadır.
using System; using System.Collections.Generic; using System.Linq; using Matriks.Data.Symbol; using Matriks.Engines; using Matriks.Indicators; using Matriks.Symbols; using Matriks.Trader.Core; using Matriks.Trader.Core.Fields; 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 CrossMov : 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.Min5)] public SymbolPeriod SymbolPeriod; [Parameter(5)] public decimal BuyOrderQuantity; [Parameter(5)] public decimal SellOrderQuantity; [Parameter(5)] public int MovPeriod; [Parameter(22)] public int MovPeriod2; // indikator tanımları. MOV mov; MOV mov2; public override void OnInit() { //Symbol = "GARAN"; //SymbolPeriod = SymbolPeriod.Min5; //BuyOrderQuantity = 1; //SellOrderQuantity = 1; //MovPeriod = 5; //MovPeriod2 = 22; AddSymbol(Symbol, SymbolPeriod); mov = MOVIndicator(Symbol, SymbolPeriod, OHLCType.Close, MovPeriod, MovMethod.Exponential); mov2 = MOVIndicator(Symbol, SymbolPeriod, OHLCType.Close, MovPeriod2, MovMethod.Exponential); SendOrderSequential(true); //Alttaki fonksiyon açıldıktan sonra parametre olarak verilen saniyede bir OnTimer fonksiyonu tetiklenir. //SetTimerInterval(3); //Alttaki fonksiyon ile tanımlanan sembol ile ilgili haber geldiğinde OnNewsReceived fonksiyonu tetiklenir. //AddNewsSymbol(Symbol); //Alttaki fonksiyon ile tanımlanan anahtar kelime ile ilgili haber geldiğinde OnNewsReceived fonksiyonu tetiklenir. //AddNewsKeyword("KAP"); // 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); } /// <summary> /// Init islemleri tamamlaninca, bardatalar kullanmaya hazir hale gelince bu fonksiyon tetiklenir. Data uzerinde bir defa yapilacak islemler icin kullanilir /// </summary> public override void OnInitCompleted() { } /// <summary> /// SetTimerInterval fonksiyonu ile belirtilen sürede bir bu fonksiyon tetiklenir. /// </summary> public override void OnTimer() { } /// <summary> /// AddNewsSymbol ve AddNewsKeyword ile haberlere kayit olunmuşsa bu fonksiyon tetiklenir. /// </summary> /// <param name="newsId">Gelen haberin id'si</param> /// <param name="relatedSymbols">Gelen haberin ilişkili sembolleri</param> public override void OnNewsReceived(int newsId, List<string> relatedSymbols) { } /// <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) { if (CrossAbove(mov, mov2)) { SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy); Debug("Alış Emri Gönderildi"); } if (CrossBelow(mov, mov2)) { SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell); Debug("Satış Emri Gönderildi"); } } /// <summary> /// Gönderilen emirlerin son durumu değiştikçe bu fonksiyon tetiklenir. /// </summary> /// <param name="order">Emrin son durumu</param> public override void OnOrderUpdate(IOrder order) { if (order.OrdStatus.Obj == OrdStatus.Filled) { } } /// <summary> /// Strateji durdurulduğunda bu fonksiyon tetiklenir. /// </summary> public override void OnStopped() { } } }