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