ZeroLag indikatöründe, fiyat çubuklarınının ZeroLag bandının üstüne kırdığı anda al, altına kırdığı anda sat sinyali üretilir.
Emirler piyasa fiyatından gönderilecektir.
Emir gönderimi ile birlikte strateji raporunda Debug sekmesine “Alış emri gönderildi.” veya “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.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; namespace Matriks.Lean.Algotrader.BuildInStrategies { [BuiltInStrategy] public class ZeroLagStrategy : 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(1)] public decimal BuyOrderQuantity; [Parameter(1)] public decimal SellOrderQuantity; [Parameter(5)] public int Period; ZEROLAG zeroLag; /// <summary> /// Strateji ilk çalıştırıldığında bu fonksiyon tetiklenir. Tüm sembole kayit işlemleri, /// indikator ekleme, haberlere kayıt olma işlemleri burada yapılır. /// </summary> public override void OnInit() { zeroLag = ZerolagIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period); 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) { var barDataModel = GetBarData(); if (CrossAbove(barDataModel, zeroLag, OHLCType.Close)) { SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy); Debug("Alış Emri Gönderildi"); Debug("Close:" + barData.BarData.Close); Debug("Zerolag:" + zeroLag.CurrentValue); } if (CrossBelow(barDataModel, zeroLag, OHLCType.Close)) { SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell); Debug("Satış Emri Gönderildi"); Debug("Close:" + barData.BarData.Close); Debug("Zerolag:" + zeroLag.CurrentValue); } } /// <summary> /// Strateji durdurulduğunda bu fonksiyon tetiklenir. /// </summary> public override void OnStopped() { } } }