MatriksIQ Destek
Matriks Destek
Matriks Web Destek
Matriks Mobile Destek
5 beğenilme 0 beğenilmeme
1,984 kez görüntülendi

                                                      BİR STRATEJİYE STOP EKLEMEK

 

Merhaba,

Var olan bir stratejiye stop eklemek için, ilk olarak aşağıdaki stop komutlarını bilmemiz gerekir.

 

            // %5 zarar durdur
            // StopLoss(Symbol, SyntheticOrderPriceType.Percent, 5);
                                                           
            // %5 kar al
            // TakeProfit(Symbol, SyntheticOrderPriceType.Percent, 5);
                                                           
            // %5 izsürenstop
            TrailingStopLoss(Symbol, SyntheticOrderPriceType.Percent, 5);

 

Yüzde olarak değil de, miktar olarak tanımlamak istersek,

SyntheticOrderPriceType.Percent

Yerine,

SyntheticOrderPriceType.PricePoint

Gelmelidir.

Mesela,

StopLoss(Symbol, SyntheticOrderPriceType.PricePoint, 0.20);

 

Gibi. Tabii bu durumda, yazacağımız rakam da puan olmalıdır. Yukarıdaki ifadede, stop seviyesi 0.2 puandır.

 

İpucu: Normal şartlar altında, stop seviyelerinin yüzde olarak uygulanması, genelde kullanmak açısından daha doğrudur.

Bilgi: Program içinde, hazır stratejilerden SMA_Bitmex_TPSL stratejisi stop uygulaması içermektedir.

 

**

Stop ifadesinin genel şablonu şu şekildedir:

TakeProfit( string symbol, SyntheticOrderPriceType SyntheticOrderPriceType, decimal stopLevel )

 

Genellikle şöyle ifade edilir:

StopLoss(Symbol, SyntheticOrderPriceType.Percent, Zarar_Durdur_Yuzdesi);

StopLoss(Symbol, SyntheticOrderPriceType.Percent, 1);

 

Yukarıda 2. Satırda olduğu gibi, sabit bir rakam yazabiliriz. Bu durumda, strateji bu rakamı baz alarak çalışacak, çalıştırma esnasında bize bir şey sormayacaktır.

Bu, normalde tercih edeceğimiz bir durum olmayacaktır.

Bu sebeple, öncesinde bir değişken tanımlamayı tercih ederiz.

Public class bölümünde şu şekilde değişken tanımlayabiliriz:

	//Burdaki değer ile yüzdeli stoploss kurulur.
		[Parameter(1)]
		public decimal Zarar_Durdur_Yuzdesi;

      

Yukarıdaki tanımlamayı yapıp, daha sonra aşağıdaki kod satırını:

StopLoss(Symbol, SyntheticOrderPriceType.Percent, Zarar_Durdur_Yuzdesi);

 

AL ya da, Açığa Sat emir gönderim satırının altına eklemeliyiz.

 

**

Örnek:

Kodun içinde değişken tanımlama kısmına geliyorum.

Son değişkeni kopyalayıp, aynısını altına yapıştırıyorum.

 

Sonra, eklediğim değişkende, hedefime uygun olarak düzenlemeyi yapıyorum.

 

Rakamların karışmaması için, 2 rakamını 1.5 yaptım. Değişken olarak tanımladığım için backtest veya çalıştırma aşamasında zaten göreceğim.

İsmini de yukarıda göreceğiniz şekilde değiştirdim.

Sonra, Alış satırının altına stop emir kodunu ekliyorum.

 

Debug fonksiyonun işlevi ayrıdır. Kendimizi bilgilendirmek için kullanırız. Ayrıca anlatılacaktır.

Dilersek, stoploss kodumuzun altına da, debug ekleyerek kendimize çıktılar kısmında, bilgilendirme alabiliriz.

 

Önemli Bir Detay: Yukarıdaki resimde, emir gönderim satırı içinde sembol tanımının Synbol olduğunu görüyoruz. Bazen orada, farklı olarak Symbol1 ya da daha farklı bir tanım olabilir.

Bu durumda, bizim de, stop komutumuzun içinde yer alan Symbol ifadesini aynı şekilde değiştirmemiz gerekir.

Değiştirmez isek, kodun içeriğine göre, ya hata mesajı alırız, bunu fark edip düzeltmek kolay olacaktır.

Ya da yanlış bir sembole emir gönderilmesine sebep olabiliriz. Dikkat edelim lütfen.

 

İşlem tamamlandı. Kodu derle yapabiliriz.

*

Backtest yapmayı denersek, karşımıza çıkacak pencerede ilgili stop seçeneğini de görebiliriz.

 

Benzer biçimde, diğer stopları da ekleyebiliriz.

 

DİKKAT: Stop ifadesinin AL koşulu altına eklenmesi, sadece AL pozisyonuna uygulanmasını garanti etmez. Oraya eklememiz, görsel / işlevsel bir kolaylık içindir.
Esasen, stop ifadesi, pozisyon açtığını var saydığı her emre uygulanır. 
Bu sebeple, stopların doğru çalışması için: Stratejinin AL ile başlaması ve emirlerin sıralı gönderilmesi gerekir. 
AL ile başlatmadığımız strateji SAT emrini açığa sat olarak algılar. Ve stop buna göre devreye girer. 
Sıralı gönder seçmediğimiz takdirde de, stop gerçekleşmesine rağmen SAT emrinin tekrar gönderilmesi gibi sorunlarla kaşılaşabiliriz. 
Eğer daha serbest olarak kullanmak istiyorsanız, kodun içine ayrıca pozisyon kontrolü vb. koymalıyız. 
Bu konuda ayrıca bir çalışma yapacağız. 

 

**

Dilersek, peş peşe Kar Al – Zarar Durdur ve İz süren stop emirleri de girebiliriz. Hangisi önce gerçekleşirse, o çalışacaktır.

 

Hayırlı kazançlar dileriz.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Algoritmik Trading kategorisinde (5,005 puan) tarafından
tarafından düzenlendi | 1,984 kez görüntülendi
0 0
Merhaba aşağıda algoritma sihirbazında oluşturduğum yapıya yazınıza göre kar al ekledim. Ancak hem bactestte hem canlıda kar al çalışmıyor. Zahmet olmazsa kontrol edebilir misiniz

 

using System;

using System.Collections.Generic;

using System.Linq;

using Matriks.Data.Symbol;

using Matriks.Engines;

using Matriks.Indicators;

using Matriks.Symbols;

using Matriks.Trader.Core;

using Matriks.Trader.Core.Fields;

using Matriks.Lean.Algotrader.AlgoBase;

using Matriks.Lean.Algotrader.Models;

using Matriks.Lean.Algotrader.Trading;

using Matriks.AI;

using Matriks.AI.AiParameters;

using Matriks.AI.Data;

using Matriks.Trader.Core.TraderModels;

 

namespace Matriks.Lean.Algotrader

{

public class deneme2 : 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("MATIC_USDT_FBIN")]

public string Symbol1;

 

 

[Parameter(SymbolPeriod.Min)]

public SymbolPeriod SymbolPeriod1;

 

 

[Parameter(40)]

public int TottPeriod1;

 

[Parameter(1)]

public decimal TottOpt1;

 

[Parameter(0.001)]

public decimal TottTwinOttCoef1;

 

[Parameter(MovMethod.VAR)]

public MovMethod TottMovMethod1;

 

[Parameter(5)]

public decimal OrderQuantity1;

 

[Parameter(false)]

public bool IsReduceOnly1;

 

[Parameter(false)]

public bool IsReduceOnly2;

 

[Parameter(CryptoLeverageType.Isolated)]

public CryptoLeverageType LeverageType2;

 

[Parameter(false)]

public bool IsReduceOnly3;

 

[Parameter(1)]

public decimal Leverage3;

 

[Parameter(5)]

public decimal OrderQuantity4;

 

[Parameter(false)]

public bool IsReduceOnly4;

 

[Parameter(false)]

public bool IsReduceOnly5;

 

[Parameter(CryptoLeverageType.Isolated)]

public CryptoLeverageType LeverageType5;

 

[Parameter(false)]

public bool IsReduceOnly6;

 

[Parameter(1)]

public decimal Leverage6;

 

[Parameter(1.5)]

public decimal KarAlYüzdesi;

 

TOTT tott;

 

 

 

public override void OnInit()

{

 

tott = TOTTIndicator(Symbol1, SymbolPeriod1, OHLCType.Close, TottPeriod1, TottOpt1, TottTwinOttCoef1, TottMovMethod1);

 

 

 

 

SendOrderSequential(true, Side.All);

WorkWithPermanentSignal(true);

 

//Alttaki fonksiyon açıldıktan sonra parametre olarak verilen saniyede bir OnTimer fonksiyonu tetiklenir.

// SetTimerInterval(3600);

 

//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 OnInitCompleted()

{

 

}

 

/// <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(BarDataEventArgs barData)

{

if (CrossAbove(tott, tott, 0, 1))

{

SendMarketOrder(Symbol1, OrderQuantity1, OrderSide.Buy, includeAfterSession:false, isReduceOnly : IsReduceOnly1);

SetLeverageType(Symbol1, LeverageType2);

SetLeverage(Symbol1, Leverage3);

TakeProfit(Symbol1, SyntheticOrderPriceType.Percent, 5);

}

if (CrossBelow(tott, tott, 0, 2))

{

SendMarketOrder(Symbol1, OrderQuantity4, OrderSide.Sell, includeAfterSession:false, isReduceOnly : IsReduceOnly4);

SetLeverageType(Symbol1, LeverageType5);

SetLeverage(Symbol1, Leverage6);

TakeProfit(Symbol1, SyntheticOrderPriceType.Percent, 5);

}

 

}

 

/// <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)

{

}

 

/// <summary>

/// Strateji durdurulduğunda bu fonksiyon tetiklenir.

/// </summary>

public override void OnStopped()

{

}

}

}
0 0
IQ'da sentetik bir emiri iptal etmek istiyorsak nasıl bir kod eklememiz gerekir...

Teşekkürler..

1 cevap

1 beğenilme 0 beğenilmeme

Merhabalar,

Dilerseniz formülünüzü aşağıdaki şekilde test edebilirsiniz.

using System;
using System.Collections.Generic;
using System.Linq;
using Matriks.Data.Symbol;
using Matriks.Engines;
using System.Windows.Media;
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 deneme2_2 : 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("ETH_USDT_BIN")]
			public string Symbol;

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

		[Parameter(40)]
			public int TottPeriod1;

		[Parameter(1)]
			public decimal TottOpt1;

		[Parameter(0.001)]
			public decimal TottTwinOttCoef1;

		[Parameter(MovMethod.VAR)]
			public MovMethod TottMovMethod1;

		[Parameter(5)]
			public decimal BuyOrderQuantity;

		[Parameter(5)]
			public decimal SellOrderQuantity;

		[Parameter(3)]
			public int Kaldirac;

		[Parameter(1.5)]
			public decimal KarAlYüzdesi;


		TOTT tott;



		/// <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);
			tott = TOTTIndicator(Symbol, SymbolPeriod, OHLCType.Close, TottPeriod1, TottOpt1, TottTwinOttCoef1, TottMovMethod1);


			SendOrderSequential(true, Side.All);
			WorkWithPermanentSignal(true);

			if (Kaldirac>30)
			{
				// kaldıraç oranı
				SetLeverage(Symbol, 3);
				// kaldıraç tipi - true isolated, false cross
				SetLeverageType(Symbol, true);
			}else
			{
				SetLeverage(Symbol, Kaldirac);
				SetLeverageType(Symbol, true);
			}
		}


		public override void OnDataUpdate(BarDataCurrentValues barDataCurrentValues)
		{
			if (CrossAbove(tott, tott, 0, 1) && LastOrderSide.Obj != Side.Buy)
			{
				if (LastOrderSide.Obj == Side.All)
				{
					SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy);
					TakeProfit(Symbol, SyntheticOrderPriceType.Percent, KarAlYüzdesi);
				}else
				{
					SendMarketOrder(Symbol, BuyOrderQuantity * 2, OrderSide.Buy);
					TakeProfit(Symbol, SyntheticOrderPriceType.Percent, KarAlYüzdesi);
				}
				Debug("Alış Emri Gönderildi");
			}

			if (CrossBelow(tott, tott, 0, 2) && LastOrderSide.Obj != Side.Sell)
			{
				if (LastOrderSide.Obj == Side.All)
				{
					SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell);
					TakeProfit(Symbol, SyntheticOrderPriceType.Percent, KarAlYüzdesi);
				}else
				{
					SendMarketOrder(Symbol, SellOrderQuantity * 2, OrderSide.Sell);
					TakeProfit(Symbol, SyntheticOrderPriceType.Percent, KarAlYüzdesi);
				}
				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)
			{

			}
		}

		/// <summary>
		/// Strateji durdurulduğunda bu fonksiyon tetiklenir.
		/// </summary>
		public override void OnStopped()
		{
		}
	}
}

İyi çalışmalar.

 

(3,504 puan) tarafından
0 0
Merhabalar

yardımcı olduğunuz için teşekkür ederim

sistem  hem bactestte hem canlıda çalışıyor. yalnız şöyle bir durum oluşuyor. takeprofit emri gelene kadar sorun yok. teke profit emrinden sonraki ilk emirde x  kadar adet  başlayıp 2x  adet çalışmaya devam etmiyor. takeprofitten  sonraki bütün emirler 2x olarak sürüyor. birkaç gündür araştıryorum yapamadım yardımcı olabilir misiniz
1 0

Merhabalar,

Aşağıdaki paylaşılan stratejiyi inceleyip, test edebilirsiniz.

using System;
using System.Collections.Generic;
using System.Linq;
using Matriks.Data.Symbol;
using Matriks.Engines;
using System.Windows.Media;
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 deneme2_21 : 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("ETH_USDT_BIN")]
			public string Symbol;

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

		[Parameter(40)]
			public int TottPeriod1;

		[Parameter(1)]
			public decimal TottOpt1;

		[Parameter(0.001)]
			public decimal TottTwinOttCoef1;

		[Parameter(MovMethod.VAR)]
			public MovMethod TottMovMethod1;

		[Parameter(5)]
			public decimal BuyOrderQuantity;

		[Parameter(5)]
			public decimal SellOrderQuantity;

		[Parameter(3)]
			public int Kaldirac;

		[Parameter(1.5)]
			public decimal KarAlYüzdesi;


				[Parameter(true)]
		public bool AcigaSatisYapilsin;

		[Parameter(false)]
		public bool AksamSeansiniDahilEt;

		List<string> orderIDList = new List<string>();

		string orderID;
		
		TOTT tott;



		/// <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);
			tott = TOTTIndicator(Symbol, SymbolPeriod, OHLCType.Close, TottPeriod1, TottOpt1, TottTwinOttCoef1, TottMovMethod1);


			SendOrderSequential(true, Side.Buy);
			
			WorkWithPermanentSignal(true);
			if (AcigaSatisYapilsin)
			{
				SendOrderSequential(true, Side.All);
				SendOrderSequentialForShort(true, Side.All);
			}else
			{
				SendOrderSequential(true, Side.Buy);
			}
			SetLeverage(Symbol, Kaldirac);
			SetLeverageType(Symbol, true);
		}


		public override void OnDataUpdate(BarDataCurrentValues barDataCurrentValues)
		{
			if (CrossAbove(tott, tott, 0, 1))
			{
				FX_Alis();
				TakeProfit(Symbol, SyntheticOrderPriceType.Percent, KarAlYüzdesi);
			}

			if (CrossBelow(tott, tott, 0, 2))
			{
				FX_Satis();
				TakeProfit(Symbol, SyntheticOrderPriceType.Percent, KarAlYüzdesi);

			}

		}

	public override void OnInitComplated()
		{
			FX_PiyasaTipi();
		}

		public void FX_Alis()
		{
			if (LastOrderSide.Obj != Side.Buy)
			{
				if (LastOrderSide.Obj == Side.All || !AcigaSatisYapilsin)
				{
					orderID = SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy, includeAfterSession:AksamSeansiniDahilEt);
					orderIDList.Add(orderID);
					Debug("Alış emri gönderildi.[ " + BuyOrderQuantity + " adet ]");
				}else
				{
					if (piyasaTipleri == PiyasaTipleri.BISTPP)
					{
						// Açık pozisyonu kapat
						orderID = SendMarketCloseShortOrder(Symbol, BuyOrderQuantity);
						orderIDList.Add(orderID);
						Debug("Açık pozisyonlar kapatıldı.[ " + BuyOrderQuantity + " adet ]");

						// Al
						orderID = SendMarketOrder(Symbol, BuyOrderQuantity, OrderSide.Buy, includeAfterSession:AksamSeansiniDahilEt);
						orderIDList.Add(orderID);
						Debug("Alış emri gönderildi.[ " + BuyOrderQuantity + " adet ]");
					}else
					{
						// pozsiyon kapat ve al
						orderID = SendMarketOrder(Symbol, BuyOrderQuantity * 2, OrderSide.Buy, includeAfterSession:AksamSeansiniDahilEt);
						orderIDList.Add(orderID);
						Debug("Alış emri gönderildi.[ " + (BuyOrderQuantity * 2) + " adet ]");
					}
				}
				LastOrderSide.Obj = Side.Buy;
			}
		}

		public void FX_Satis()
		{
			if (LastOrderSide.Obj != Side.Sell)
			{
				if (LastOrderSide.Obj == Side.All || !AcigaSatisYapilsin)
				{
					if (piyasaTipleri == PiyasaTipleri.BISTPP)
					{
						if (AcigaSatisYapilsin)
						{
							orderID = SendShortSaleMarketOrder(Symbol, SellOrderQuantity);
							orderIDList.Add(orderID);
							Debug("Açığa satış yapıldı.[ " + (SellOrderQuantity) + " adet ]");
						}else
						{
							orderID = SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell, includeAfterSession:AksamSeansiniDahilEt);
							orderIDList.Add(orderID);
							Debug("Satış emri gönderildi.[ " + (SellOrderQuantity) + " adet ]");
						}
					}else
					{
						orderID = SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell, includeAfterSession:AksamSeansiniDahilEt);
						orderIDList.Add(orderID);
						Debug("Satış emri gönderildi.[ " + (SellOrderQuantity) + " adet ]");
					}

				}else
				{
					if (piyasaTipleri == PiyasaTipleri.BISTPP)
					{
						orderID = SendMarketOrder(Symbol, SellOrderQuantity, OrderSide.Sell, includeAfterSession:AksamSeansiniDahilEt);
						orderIDList.Add(orderID);
						Debug("Satış emri gönderildi.[ " + (SellOrderQuantity) + " adet ]");

						orderID = SendShortSaleMarketOrder(Symbol, SellOrderQuantity);
						orderIDList.Add(orderID);
						Debug("Açığa satış yapıldı.[ " + (SellOrderQuantity) + " adet ]");
					}else
					{
						orderID = SendMarketOrder(Symbol, SellOrderQuantity * 2, OrderSide.Sell, includeAfterSession:AksamSeansiniDahilEt);
						orderIDList.Add(orderID);
						Debug("Satış emri gönderildi.[ " + (SellOrderQuantity * 2) + " adet ]");
					}
				}
				LastOrderSide.Obj = Side.Sell;
			}
		}

		[Output]
		public string Sembol1 = "";

		[Output]
		public string Sembol2 = "";

		enum PiyasaTipleri
		{
			BISTPP,
			BISTVIOP,
			KRIPTOBINANCE,
			KRIPTOBINANCEFUTURE,
			KRIPTOBITMEX,
			KRIPTOBTCTURK
		}

		PiyasaTipleri piyasaTipleri = PiyasaTipleri.BISTPP;

		public void FX_PiyasaTipi()
		{
			Sembol1 = Symbol;
			Sembol2 = Symbol;

			var SymbolDetail = GetSymbolDetail(Symbol);

			if (SymbolDetail.ExchangeDetail.ExchangeCode == PiyasaTipleri.BISTPP.ToString())
			{
				piyasaTipleri = PiyasaTipleri.BISTPP;
			}else if (SymbolDetail.ExchangeDetail.ExchangeCode == PiyasaTipleri.BISTVIOP.ToString())
			{
				piyasaTipleri = PiyasaTipleri.BISTVIOP;
			}else if (SymbolDetail.ExchangeDetail.ExchangeCode == "")
			{
				Sembol1 = Symbol.Split('_')[0];
				Sembol2 = Symbol.Split('_')[1];

				var _split = Symbol.Split('_');

				if (_split.Count() == 3)
				{
					if (Symbol.Split('_')[2].Contains("BIN"))
					{
						piyasaTipleri = PiyasaTipleri.KRIPTOBINANCE;
					} else if (Symbol.Split('_')[2].Contains("FBIN"))
					{
						piyasaTipleri = PiyasaTipleri.KRIPTOBINANCEFUTURE;
						Sembol1 = Symbol;
						Sembol2 = Symbol;

					}else if (Symbol.Split('_')[2].Contains("BMEX"))
					{
						piyasaTipleri = PiyasaTipleri.KRIPTOBITMEX;
					}
				}else
				{
					piyasaTipleri = PiyasaTipleri.KRIPTOBTCTURK;
				}

			}
		}


		public override void OnOrderUpdate(IOrder order)
		{
			if (order.OrdStatus.Obj == OrdStatus.Filled)
			{
				

			}

			if (order.OrdStatus.Obj == OrdStatus.Filled && !orderIDList.Contains(order.CliOrdID) && AcigaSatisYapilsin)
			{
				LastOrderSide.Obj = Side.All;
			}
		}



	}
}

İyi çalışmalar.

0 0

sayın asiyang tekrar merhaba

buradaki stratejide de yine take profitten sonra işlemler belli bir müddet 2x adet devam ediyor

<img alt="" src="denied:

Hoş geldiniz, Matriks Destek Platformu sizlere sorularınızın hızlıca cevaplanması için bir ortam sağlar. Sorduğunuz ve cevapladığınız soruların ve yorumlarınızın aldığı oylar üzerinden puan kazanırsınız. Puan sistemine bağlı kampanyamızla ücretsiz kullanım avantajlarından faydalanabilirsiniz.



4,011 soru
3,963 cevap
2,797 yorum
2,962 kullanıcı