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()
		{
		}
	}
}