13.01.2022
0
1
121
100

Inverse Fisher Transform on RSI


Bu indikatör -1 ve +1 arasında değerler üretmektedir.


İndikatör -0.5 seviyesini yukarı kırdığında AL, +0.5 seviyesini aşağıya kırdığında SAT olarak yorumlanabilir

using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using Matriks.Data.Identifiers;
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;
/*
	INVERSE FISHER TRANSFORM on RSI (John EHLERS)
	by KIVANÇ @fr3762 on twitter
	
	
	MATRİKS INDICATOR BUILDER FORMÜLÜ:
	
	VALUE1:= 0.1*(rsi(C,5)-50);
	VALUE2:= Mov(VALUE1,9,w);
	IFISH:=(Exp(2*VALUE2)-1)/(Exp(2*VALUE2)+1);
	IFISH;
	0.5;
	-0.5

	Kıvanç Özbilgiç

	https://drive.google.com/drive/folders/1GmwFzvLU4raNBwVWLrI57G3u4eMQbMF0

*/
namespace Matriks.Lean.Algotrader
{
	//Ilk parametre indikatörün adı, sınıfın adıyla aynı olmalıdır.
	//Ikinci parametre indikatörün Dataserisinin üzerine mi yeni pencereye mi ekleneceğini belirtir. Yeni pencere için ->IndicatorDrawingArea.NewWindow , Data Serisi için IndicatorDrawingArea.OnDataSeries
	[IndicatorInformationAttribute("IFTRSIKripex", IndicatorDrawingArea.NewWindow)]
	//Indikatörün çizgilerinin isimleri
	[IndicatorLineInformationAttribute(new []
		{
			"IFTRSI"
		})]

	public class IFTRSIKripex : MatriksIndicator
	{

		//Indicator opsiyon panelinde değerleri değiştirebildiğimiz parametreler. Int, Bool, Decimal ve Enum değerleri alabilir.Tüm değişken tiplerini DefaultValue ile tanımlarız. 
		[DefaultValue(9)]
		public int MovPeriod
		{
			get; set;
		}

		[DefaultValue(5)]
		public int RsiPeriod
		{
			get; set;
		}

		RSI rsi;

		MOV mov;

		decimal VALUE1, VALUE2;
		double IFISH;

		public sealed override void OnInit()
		{
			rsi = RSIIndicator(Symbol, SymbolPeriod, OHLCType.Close, RsiPeriod);

			mov = new MOV(MovPeriod, MovMethod.W);

			DrawHorizantal(0.5m);
			DrawHorizantal(-0.5m);

		}

		public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
		{
			VALUE1 = 0.1m * (rsi.CurrentValue - 50);

			mov.Update(VALUE1, currentBar, barDateTime);

			VALUE2 = mov.CurrentValue;

			IFISH = (Math.Exp((double)(2 * VALUE2)) -1) / (Math.Exp((double)(2 * VALUE2)) + 1);

			if (currentBar < Period)
			{
				SetLine(0, currentBar, 0);
				return ;
			}

			SetLine(0, currentBar, (decimal) IFISH);

		}
	}
}

0 Yorum