Wave Trend indikatörünün IQ'ya çevrilmiş hali aşağıdaki gibidir.
Dosya Linki:
https://destek.matriksdata.com/?qa=blob&qa_blobid=2500783699240664358
Kodu:
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;
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("WaveTrendKripex", IndicatorDrawingArea.NewWindow)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"wt1", "wt2", "wt1-wt2"
})]
public class WaveTrendKripex : 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(10)]
public int ChannelLength
{
get; set;
}
[DefaultValue(21)]
public int AverageLength
{
get; set;
}
[DefaultValue(60)]
public int OverBoughtLevel1
{
get; set;
}
[DefaultValue(53)]
public int OverBoughtLevel2
{
get; set;
}
[DefaultValue(-60)]
public int OverSoldLevel1
{
get; set;
}
[DefaultValue(-53)]
public int OverSoldLevel2
{
get; set;
}
MOV mov1, mov2, mov3, mov4;
public sealed override void OnInit()
{
mov1 = new MOV(ChannelLength, MovMethod.Exponential);
mov2 = new MOV(ChannelLength, MovMethod.Exponential);
mov3 = new MOV(AverageLength, MovMethod.Exponential);
mov4 = new MOV(4, MovMethod.Simple);
DrawHorizantal(OverBoughtLevel1);
DrawHorizantal(OverBoughtLevel2);
DrawHorizantal(0);
DrawHorizantal(OverSoldLevel1);
DrawHorizantal(OverSoldLevel2);
}
/// <summary>
/// Seçilen sembolün bardata'ları güncellendikçe bu fonksiyon tetiklenir.
/// </summary>
/// <param name="currentBar">Güncellenen bardata'nın indexteki sırası</param>
/// <param name="inputValue">Seçilen OHLC tipine göre gelen bardata'nın o anki değeri</param>
/// <param name="barDateTime">Bardata'ya gelen güncelleme zamanı</param>
public override void OnDataUpdate(int currentBar, decimal inputValue, DateTime barDateTime)
{
var _high = GetCurrentValue(Symbol, SymbolPeriod, OHLCType.High);
var _low = GetCurrentValue(Symbol, SymbolPeriod, OHLCType.Low);
var _close = GetCurrentValue(Symbol, SymbolPeriod, OHLCType.Close);
var ap = (_high + _low + _close) / 3;
mov1.Update(ap, currentBar, barDateTime);
var esa = mov1.CurrentValue;
mov2.Update(Math.Abs(ap - esa), currentBar, barDateTime);
var d = mov2.CurrentValue;
decimal ci = 0;
if (d != 0)
ci = (ap - esa) / (0.015m * d);
mov3.Update(ci, currentBar, barDateTime);
var tci = mov3.CurrentValue;
mov4.Update(tci, currentBar, barDateTime);
var wt2 = mov4.CurrentValue;
if (currentBar < AverageLength)
{
SetLine(0, currentBar, 0);
SetLine(1, currentBar, 0);
SetLine(2, currentBar, 0);
return ;
}
SetLine(0, currentBar, tci);
SetLine(1, currentBar, wt2);
SetLine(2, currentBar, tci - wt2);
}
}
}