Yukarı barları (kapanış, açılışın üstünde) sayarak, bu sayı istenilen miktara ulaştığında alım,
Aşağı barlar istenilen miktara ulaştığında satış yapılı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; using Matriks.Data.Tick; using Matriks.Enumeration; using Matriks.IntermediaryInstitutionAnalysis.Enums; using Newtonsoft.Json; namespace Matriks.Lean.Algotrader { public class Yesilyol : 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(3)] public int ConsecutiveBarsUp; [Parameter(3)] public int ConsecutiveBarsDown; [Parameter(100)] public decimal BuyOrderQuantity; [Parameter(100)] public decimal SellOrderQuantity; public int upCounter = 0; public int downCounter = 0; public override void OnInit() { 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 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(false); } /// <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> /// 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(); Debug("DataUpdate"); Debug("Open: " + barDataModel.Open[barData.BarDataIndex -1]); Debug("Close: " + barData.BarData.Close); if (barDataModel.Close[barData.BarDataIndex -1] > barDataModel.Open[barData.BarDataIndex -1]) { Debug("close: " + barDataModel.Close[barData.BarDataIndex -1] + "> open: " + barDataModel.Open[barData.BarDataIndex -1]); downCounter = 0; Debug("downCounter reset"); upCounter++; Debug("upCounter: " + upCounter); } if (barDataModel.Close[barData.BarDataIndex -1] < barDataModel.Open[barData.BarDataIndex -1]) { Debug("this bar's close: " + barDataModel.Close[barData.BarDataIndex -1] + "< open: " + barDataModel.Open[barData.BarDataIndex -1]); upCounter = 0; Debug("upCounter reset"); downCounter++; Debug("downCounter: " + downCounter); } if (upCounter >= ConsecutiveBarsUp) { SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy); Debug("Alış Emri Gönderildi"); } if (downCounter >= ConsecutiveBarsDown) { SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell); Debug("Satış Emri Gönderildi"); } } /// <summary> /// Strateji durdurulduğunda bu fonksiyon tetiklenir. /// </summary> public override void OnStopped() { } } }