0 beğenilme 0 beğenilmeme
849 kez görüntülendi

Merhaba, Matriks IQ üzerinden yazdığım robotlar emir iletmesine rağmen saniyesinde reddediliyor. Reddedilme sebebi ise yazmıyor kontrol edebilir misiniz? Bu durumu çalıştırdığım iki stratejide de yaşıyorum, iki strateji de MACD stratejsi.

Çalıştırdığım TRON tratejisi.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Media;
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
{
	public class TRX_MACD_1H_YENI : 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("TRX_USDT_BIN")]
		public string Symbol;

		[Parameter(SymbolPeriod.Min60)]
		public SymbolPeriod SymbolPeriod;

		[Parameter(7000)]
		public decimal BuyOrderQuantity;

		[Parameter(7000)]
		public decimal SellOrderQuantity;

		[Parameter(4)]
		public int MACDPeriod;

		[Parameter(5)]
		public int MACDPeriod2;

		[Parameter(2)]
		public int MACDTrigger;

		MACD macd;

		// indikator tanımları.

		/// <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()
		{
			AddSymbol(Symbol, SymbolPeriod);
			macd = MACDIndicator(Symbol, SymbolPeriod, OHLCType.Close, MACDPeriod, MACDPeriod2, MACDTrigger);

			// 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);
			//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");
		}

		/// <summary>
		/// Init islemleri tamamlaninca, bardatalar kullanmaya hazir hale gelince bu fonksiyon tetiklenir. Data uzerinde bir defa yapilacak islemler icin kullanilir
		/// </summary>
		public override void OnInitComplated()
		{

		}

		/// <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(BarDataCurrentValues barDataCurrentValues)
		{
			if (CrossAbove(macd, macd.MacdTrigger))
			{
				SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy);
				Debug("Alış Emri Gönderildi");
			}

			if (CrossBelow(macd, macd.MacdTrigger))
			{
				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="barData">Emrin son durumu</param>
		public override void OnOrderUpdate(IOrder order)
		{
			if (order.OrdStatus.Obj == OrdStatus.Filled)
			{

			}
		}
	}
}

 

Red mesajları log:

31.05.2021 19:00:01 :Fonksiyon ismi : OnOrderUpdate, Detay :  Emir Gönderildi! 
                        Hesap : 1528802689 Yön : 2 Emir Tipi : PYS 
                        Sembol : TRX_USDT_BIN Adet : 7000 Fiyat : 0 Emir Id : 
31.05.2021 19:00:02 :Fonksiyon ismi : OnOrderUpdate, Detay :  Emir Durumu Değişti! 
                        Hesap : 1528802689 Yön : 2 Emir Tipi : PYS Emir Durumu : Reddedildi
                        Sembol : TRX_USDT_BIN Adet : 7000 Fiyat :  Emir Id : 00637580844024379897
31.05.2021 21:00:00 :Fonksiyon ismi : OnOrderUpdate, Detay :  Emir Gönderildi! 
                        Hesap : 1528802689 Yön : 1 Emir Tipi : PYS 
                        Sembol : TRX_USDT_BIN Adet : 7000 Fiyat : 0 Emir Id : 
31.05.2021 21:00:02 :Fonksiyon ismi : OnOrderUpdate, Detay :  Emir Durumu Değişti! 
                        Hesap : 1528802689 Yön : 1 Emir Tipi : PYS Emir Durumu : Reddedildi
                        Sembol : TRX_USDT_BIN Adet : 7000 Fiyat :  Emir Id : 00637580916023718993

 

Teşekkürler

 

Algoritmik Trading kategorisinde (14 puan) tarafından | 849 kez görüntülendi

1 cevap

0 beğenilme 0 beğenilmeme

Merhaba,

Emir günlük kaydından reddedilme sebebini görebilirsiniz(portföy -> iptal edilen emirlerden de görülebilir)

Eğer reddedilme sebebi bakiye yetersizliği değil ise logları iqdestek@matriksdata.com mail gönderin inceleyelim.

(15,892 puan) tarafından
8,636 soru
8,590 cevap
4,821 yorum
19,785 kullanıcı