Use the results of 50+ built-in indicators of OptimusFLOW in your strategies and indicators
General
During development of your own indicators or strategy, you may require using some standard indicators, for example Moving Averages. You don't need to write any code for this, as OptimusFLOW trading platform provides you a wide set of predefined indicators. At the moment there are about 50 built-in indicators, among them:
EMA
ADX
Keltner
ROC
RSI
KAMA
AROON
and many others
Access built-in indicators
You can access built-in indicators using Core.Indicators.BuiltIn class. A good place to initiate such indicators is in an OnInit method of your script:
Indicator AC;protectedoverridevoidOnInit(){ // An example of creation AC indicator AC =Core.Indicators.BuiltIn.AC(); }
An indicator can provide some parameters and you can specify them during creation:
Indicator EMA;protectedoverridevoidOnInit(){ // An example of creation EMA indicator with parameters: // Period = 10 // PriceType = Open EMA =Core.Indicators.BuiltIn.EMA(10,PriceType.Open); }
You can create a few copies of one indicator or a few different indicators if needed:
Indicator fastEMA;Indicator slowEMA;protectedoverridevoidOnInit(){ // An example of creation a few EMA indicators with different parameters fastEMA =Core.Indicators.BuiltIn.EMA(12,PriceType.Open); slowEMA =Core.Indicators.BuiltIn.EMA(26,PriceType.Open); }
Now we need to assign the created indicator to our current script — which means it will use symbol and quotes from its parent. You can do this via AddIndicator method:
Indicator EMA;protectedoverridevoidOnInit(){ // Create EMA indicator EMA =Core.Indicators.BuiltIn.EMA(10,PriceType.Open); // Add created EMA indicator as a child to our scriptAddIndicator(EMA);}
Everything is ready to use this indicator in our calculations. After receiving new quotes it will be calculated automatically. You can access its values via GetValuemethod:
/// <summary>/// Calculation entry point. This function is called when a price data updates. /// </summary>protectedoverridevoidOnUpdate(UpdateArgs args){ // Get EMA value for current bar from first linedouble valueFromEMA =EMA.GetValue(); // Using EMA value in parent indicatorSetValue(valueFromEMA); }
In case you need to access value for previous bars or value from other indicators line you can use the offset and a lineIndex parameter of a GetValue _**_method:
/// <summary>/// Calculation entry point. This function is called when a price data updates. /// </summary>protectedoverridevoidOnUpdate(UpdateArgs args){ // Get EMA value for current bar from second linedouble valueFromEMA =EMA.GetValue(5,1); // Using EMA value in parent indicatorSetValue(valueFromEMA); }
This is a total source code of our example. We use two EMA indicators with different period and display their difference on the chart:
usingSystem.Drawing;usingTradingPlatform.BusinessLayer;namespaceIndicatorWithBuiltIn{ publicclassIndicatorWithBuiltIn:Indicator { /// <summary> /// Built in indicators /// </summary>Indicator fastEMA;Indicator slowEMA; /// <summary> /// Indicator's constructor. Contains general information: name, description, LineSeries etc. /// </summary>publicIndicatorWithBuiltIn(): base() { // Defines indicator's name and description. Name ="IndicatorWithBuiltIn"; // Defines line on demand with particular parameters.AddLineSeries("line1",Color.CadetBlue,1,LineStyle.Solid); // By default indicator will be applied on main window of the chart SeparateWindow =true; } /// <summary> /// This function will be called after creating an indicator as well as after its input params reset or chart (symbol or timeframe) updates. /// </summary>protectedoverridevoidOnInit() { // Create first instance of EMA indicator with Period 12 fastEMA =Core.Indicators.BuiltIn.EMA(12,PriceType.Open);AddIndicator(fastEMA); // Create second instance of EMA indicator with period 26 slowEMA =Core.Indicators.BuiltIn.EMA(26,PriceType.Open);AddIndicator(slowEMA); } /// <summary> /// Calculation entry point. This function is called when a price data updates. /// </summary>protectedoverridevoidOnUpdate(UpdateArgs args) { // Calculate differencedouble difference =fastEMA.GetValue() -slowEMA.GetValue(); // Use difference as a value for parent indicatorSetValue(difference); } }}
And a result of this indicator on the chart:
As you can see it was not really difficult to create this indicator. Before starting writing your own code, check first, maybe the required calculations are already available in a built-in set. OptimusFLOW team is constantly working on adding new built-in indicators. If you have any ideas and proposals, what we should add — feel free to contact us.