Merhaba, wave trend oscillator indikatörünün MatriksIQ için kodu aşağıdadır. Yeni kullanıcı indikatörü oluşturup içerisine kopyalayarak kullanabilirsiniz. Yeni oluşturduğunuz kullanıcı indikatörünün isminin "WTO" ile aynı olmasına dikkat ediniz.
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("WTO", IndicatorDrawingArea.NewWindow)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"ObLevel1(0,1)", "ObLevel2(0,1)", "OsLevel1(0,1)", "OsLevel2(0,1)", "WaveTrendOne(0,1)", "WaveTrendTwo(0,1)", "WT(0,1)"
})]
public class WTO: 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 n1
{
get; set;
}
[DefaultValue(21)]
public int n2
{
get; set;
}
[DefaultValue(60)]
public int oblevel1
{
get; set;
}
[DefaultValue(53)]
public int oblevel2
{
get; set;
}
[DefaultValue(-60)]
public int oslevel1
{
get; set;
}
[DefaultValue(-53)]
public int oslevel2
{
get; set;
}
MOV movEsa, movD, movWt1, movWt2;
public sealed override void OnInit()
{
movEsa = new MOV(n1, MovMethod.Exponential);
movD = new MOV(n1, MovMethod.Exponential);
movWt1 = new MOV(n2, MovMethod.Exponential);
movWt2 = new MOV(4, MovMethod.Simple);
}
/// <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)
{
if (currentBar < n2 && currentBar< n1)
{
SetLine(0, currentBar, 0);
SetLine(1, currentBar, 0);
SetLine(2, currentBar, 0);
SetLine(3, currentBar, 0);
SetLine(4, currentBar, 0);
SetLine(5, currentBar, 0);
SetLine(6, currentBar, 0);
SetLine(7, currentBar, 0);
return ;
}
var high = Instrument.SymbolBarData.High[currentBar];
var low = Instrument.SymbolBarData.Low[currentBar];
var close = Instrument.SymbolBarData.Close[currentBar];
var ap = (high + low + close) / 3;
movEsa.Update(ap, currentBar, barDateTime); var esa = movEsa.CurrentValue;
movD.Update(Math.Abs(ap - esa), currentBar, barDateTime); var d = movD.CurrentValue;
if (d == 0) d = 1;
var ci = (ap - esa) / (0.015m * d);
movWt1.Update(ci, currentBar, barDateTime); var wt1 = movWt1.CurrentValue;
movWt2.Update(wt1, currentBar, barDateTime); var wt2 = movWt2.CurrentValue;
SetLine(0, currentBar, oblevel1);
SetLine(1, currentBar, oblevel2);
SetLine(2, currentBar, oslevel1);
SetLine(3, currentBar, oslevel2);
SetLine(4, currentBar, wt1);
SetLine(5, currentBar, wt2);
SetLine(6, currentBar, (wt1 - wt2));
SetLine(7, currentBar, 0);
}
}
}