Bollinger Bantları %B veya Yüzde Bant Genişliği (%B), standart Bollinger Bantları göstergesinden türetilen bir göstergedir.
Bollinger Bantları, bir kıymetin fiyatına göre çizilen üç satırlık bir bant oluşturan bir volatilite göstergedir.
Orta Bant genellikle 20 Günlük Basit Hareketli Ortalamadır.
Üst ve Alt Bantlar tipik olarak SMA'nın (Orta bant) üstünde ve altında 2 standart sapmadır.
%B göstergesi, fiyatın bantlara göre nerede olduğunu ölçmek veya gösterme için kullanılır.
%B eğilimleri işlem sinyallerini belirlemede yararlı olabilir.
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("BBYuzdeBKripex", IndicatorDrawingArea.NewWindow)]
//Indikatörün çizgilerinin isimleri
[IndicatorLineInformationAttribute(new []
{
"BB &B(0,1)"
})]
public class BBYuzdeBKripex : 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(20)]
public int Period
{
get; set;
}
[DefaultValue(2)]
public decimal SSapma
{
get; set;
}
[DefaultValue(MovMethod.Simple)]
public MovMethod movMethod
{
get; set;
}
BOLLINGER bollinger;
public sealed override void OnInit()
{
bollinger = BollingerIndicator(Symbol, SymbolPeriod, OHLCType.Close, Period, SSapma, movMethod);
}
decimal bb;
/// <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 close = Instrument.SymbolBarData.Close[currentBar];
if (currentBar < Period)
{
//SetLine fonksiyonu indikatördeki noktaları kuran fonksiyondur
//Ilk paramatre indicatordeki hangi çizginin güncelleneceği bilgisidir.
//Ikinci parametre güncellenecek çizginin hangi indexinin güncelleneceği bilgisidir.
//Ucüncü parametre güncellenecek çizginin indexinin alacağı değerdir.
SetLine(0, currentBar, 0);
return ;
}
// %B:=(C-BBandBot(C,PER,E,SS))/(BBandTOP(C,PER,E,SS)-BBandBOT(C,PER,E,SS));
if (bollinger.Bollingerup.CurrentValue - bollinger.BollingerDown.CurrentValue>0)
{
bb = (close - bollinger.BollingerDown.CurrentValue) / (bollinger.Bollingerup.CurrentValue - bollinger.BollingerDown.CurrentValue);
}else
{
bb = 0;
}
SetLine(currentBar, bb);
}
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;
}
}
}