Merhabalar,
Aşağıda bir adet camerilla pivot indikatörü mevcuttur.
Bahsettiğiniz formül daha farklı ise, lütfen Matriks formülünü paylaşınız yardımcı olmaya çalışalım.
İyi çalışmalar.
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("CamerillaPivot", IndicatorDrawingArea.NewWindow)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"R1", "R2", "R3", "R4", "R5", "R6", "S1", "S2", "S3", "S4", "S5", "S6"
})]
public class CamerillaPivot : 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(5)]
public int Period
{
get; set;
}
public sealed override void OnInit()
{
}
/// <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 H = Instrument.SymbolBarData.High[currentBar];
var L = Instrument.SymbolBarData.Low[currentBar];
var C = Instrument.SymbolBarData.Close[currentBar];
var R1 = (H - L) * 1.1m / 12m + C;
var R2 = (H - L) * 1.1m / 6m + C;
var R3 = (H - L) * 1.1m / 4m + C;
var R4 = (H - L) * 1.1m / 2m + C;
var S1 = C - (H - L) * 1.1m / 12m;
var S2 = C - (H - L) * 1.1m / 6m;
var S3 = C - (H - L) * 1.1m / 4m;
var S4 = C - (H - L) * 1.1m / 2m;
var R5 = R4 + 1.168m * (R4 - R3);
var R6 = (H / L) * C;
var S5 = S4 - 1.168m * (S3 - S4);
var S6 = C - (R6 - C);
SetLine(0, currentBar, R1);
SetLine(1, currentBar, R2);
SetLine(2, currentBar, R3);
SetLine(3, currentBar, R4);
SetLine(4, currentBar, R5);
SetLine(5, currentBar, R6);
SetLine(6, currentBar, S1);
SetLine(7, currentBar, S2);
SetLine(8, currentBar, S3);
SetLine(9, currentBar, S4);
SetLine(10, currentBar, S5);
SetLine(11, currentBar, S6);
}
private decimal GetTypicalPrice(int barIndex)
{
//Seçilen sembole ait bardataya Instrument.SymbolBarData'nın altında ulaşabiliriz.
if (!Instrument.SymbolBarData.Close.ContainsKey(barIndex)) return 0;
return (Instrument.SymbolBarData.Close[barIndex] + Instrument.SymbolBarData.High[barIndex] + Instrument.SymbolBarData.Low[barIndex]) / 3;
}
}
}