23.12.2021
0
1
119
100

TEMA Tripel Exponential Moving Average (3'lü Üssel Hareketli Ortalama)


Klasik HO gibi

Al: Fiyat HOyu Yukarı kesince

Sat: Fiyat HOyu Aşağı kesince


Prime Kodu

pd:=input("period",1,500,30);

K1:=mov(c,pd,e);

TEMA:=3*K1-3*mov(K1,pd,e)+mov(mov(K1,pd,e),pd,e);

TEMA

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;
/*
	TEMA Formula byKIVANC
	
	period:=input("TEMA period:",1,500,30);
	TEMA:=3*mov(c,period,e)-3*mov(mov(c,period,e),period,e)+mov(mov(mov(c,period,e),period,e),period,e);
	TEMA
	
	Kıvanç Özbilgiç
	https://drive.google.com/drive/folders/0B4PaGyTCt4lDa3lDUzdBdXF2dW8	
*/
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("TEMAKripex", IndicatorDrawingArea.OnDataSeries)]
	//Indikatörün çizgilerinin isimleri
	[IndicatorLineInformationAttribute(new []
		{
			"TEMAKripex(0)"
		})]

	public class TEMAKripex : 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(30)]
		public int Period
		{
			get; set;
		}

		[DefaultValue(MovMethod.Exponential)]
		public MovMethod movMethod
		{
			get; set;
		}

		MOV mov1, mov2, mov3;

		public sealed override void OnInit()
		{
			mov1 = MOVIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period, movMethod);
			mov2 = MOVIndicator(mov1, Period, movMethod);
			mov3 = MOVIndicator(mov2, Period, movMethod);

		}

		decimal TEMA;
		public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
		{
			// TEMA:=3*mov(c,period,e)-3*mov(mov(c,period,e),period,e)+mov(mov(mov(c,period,e),period,e),period,e);

			TEMA = 3 * mov1.CurrentValue -3 * mov2.CurrentValue + mov3.CurrentValue;

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

			SetLine(currentBar, TEMA);

		}
	}
}

0 Yorum