Quantower_in
  • Welcome to Quantower.in Help
  • Getting started
    • What's new
    • Installation
    • First start
    • Platform update
    • Control center
    • Workspaces, Binds, Groups
    • Templates
    • Set as Default
    • Symbols lookup
    • Table management
    • Backup & restore manager
    • General settings
    • Quantower Account
    • Quantower Licenses
  • Connections
    • Connections manager
    • Connection to Quandl
  • Analytics panels
    • Chart
      • Chart types
        • Time aggregation
        • Renko
        • Heiken Ashi
        • Kagi
        • Points & Figures
        • Range bars
        • Line break
        • Volume Bars
      • Chart overlays
      • Technical indicators
        • Oscillators
          • Aroon Indicator
          • Moving Average Convergence/Divergence
          • Awesome Oscillator
          • Accelerator Oscillator
          • %R Larry Williams
          • Momentum
          • Rate of Change
          • Commodity Channel Index
        • Moving averages
          • Exponential Moving Average
          • Simple moving average
        • Volatility
          • Average True Range
          • Standard deviation
        • Trend
          • ZigZag
      • Drawing tools
      • Volume analysis tools
        • Cluster chart
        • Volume profiles
        • Time statistics
        • Time histogram
        • Historical Time & Sales
      • Power Trades
      • VWAP
    • Watchlist
    • Time & Sales
    • Price Statistic
    • DOM Surface
    • Order Flow Surface
    • Option Analytics
    • TPO Profile Chart
  • Trading panels
    • Order Entry
      • Order Types
    • DOM Trader
    • Market depth
    • Trading simulator
    • History Player
    • FX Cell
  • Portfolio panels
    • Positions
    • Working Orders
    • Trades
    • Orders History
    • Synthetic Symbols
    • Historical Symbols
  • Information panels
    • Account info
    • Symbol Info
    • Currencies Exposure
    • Event Log
    • RSS
    • Reports
  • Miscellaneous
    • History Exporter
    • Symbol Mapping Manager
    • Market heat map
    • Stat matrix
    • Exchange times
    • Quote Board
    • Browser
    • Excel and RTD function
  • Quantower Algo
    • Introduction
    • Install for Visual Studio
    • Simple Indicator
    • Input Parameters
    • Built-In indicators access
    • Indicator with custom painting (GDI)
    • Using markers with indicators
    • Adding a custom indicator to Watchlist
    • Downloading history
    • Simple strategy
    • Access to trading portfolio
    • Trading operations
    • Example: Simple Moving Average
Powered by GitBook
On this page
  • Input parameters
  • Indicator's general info
  • Core logic
  • All source code

Was this helpful?

  1. Quantower Algo

Example: Simple Moving Average

In this example we will develop a simple moving average indicator. Let's, create an indicator template project and start.

Input parameters

First of all it is important to decide what parameters will our indicator have. We are building a simple moving average, so it will have only two parameters: Period and Price type, that will be used for calculations

#region Parameters
// First input parameter
[InputParameter("Period of Simple Moving Average", 0, 1, 999, 1, 1)]
public int Period = 10;

// Second input parameter
[InputParameter("Sources prices for MA", 1, variants: new object[]{
    "Close", PriceType.Close,
    "Open", PriceType.Open,
    "High", PriceType.High,
    "Low", PriceType.Low,
    "Typical", PriceType.Typical,
    "Median", PriceType.Median,
    "Weighted", PriceType.Weighted
})]
public PriceType SourcePrice = PriceType.Close;
#endregion Parameters

Ok, done let's go ahead

Indicator's general info

Our next step is to set a general indicators info, all this information you will see in Indicator's lookup, when you decide to select it. Also, here we need to define how many data series will our indicator have and should it be drawn in separate window or directly on a chart.

All these tasks we can solve in constructor function, ok great, let's do it

public SMA()
    : base()
{
    // Here we set an indicator's name and description
    Name = "Simple Moving Average Example";
    Description = "Average price for the last N periods";
    ShortName = "SMA (" + Period + ":" + SourcePrice.ToString() + ")";

    // Our indicator has only one line 
    AddLineSeries("SMA", Color.Red, 1, LineStyle.Solid);

    //Indicator will be drawn directly on chart 
    SeparateWindow = false;
}

Core logic

We will save OnInit function empty, because our indicator does not require any one-time logic that should be executed when we add indicator on a chart

protected override void OnInit()
{

}

All calculations will occur when we receive a new quote, to process it we need to override OnUpdate function

protected override void OnUpdate(UpdateArgs args)
{
    // Checking, if current amount of bars
    // more, than period of moving average. If it is
    // then the calculation is possible
    if (Count <= Period)
        return;

    double sum = 0.0; // Sum of prices
    for (int i = 0; i < Period; i++)
        // Adding bar's price to the sum
        sum += GetPrice(SourcePrice, i);

    // Set value to the "SMA" line buffer.
    SetValue(sum / Period);
}

Pay your attention at:

if (Count <= Period)
    return;

Here we check is it enough historical bars to calculate one indicator's point, if yes - we continue calculation otherwise skip it.

To calculate average price we need to request price data, we can do it by calling GetPrice function

sum += GetPrice(SourcePrice, i);

Once, all calculations are done we set the result value to indicators data serie

// Set value to the "SMA" line buffer.
SetValue(sum / Period);

All source code

That is all, that was easy. As a conclusion take a look at all source code

// Copyright QUANTOWER LLC. © 2017-2018. All rights reserved.
using System;
using System.Drawing;
using TradingPlatform.BusinessLayer;

namespace MovingAverages
{
    public class SMA : Indicator
    {
        #region Parameters
        // First input parameter
        [InputParameter("Period of Simple Moving Average", 0, 1, 999, 1, 1)]
        public int Period = 10;

        // Second input parameter
        [InputParameter("Sources prices for MA", 1, variants: new object[]{
            "Close", PriceType.Close,
            "Open", PriceType.Open,
            "High", PriceType.High,
            "Low", PriceType.Low,
            "Typical", PriceType.Typical,
            "Median", PriceType.Median,
            "Weighted", PriceType.Weighted
        })]
        public PriceType SourcePrice = PriceType.Close;
        #endregion Parameters

        /// <summary>
        /// Indicator's constructor. Contains general information: name, description, LineSeries etc. 
        /// </summary>
        public SMA()
            : base()
        {
            // Here we set an indicator's name and description
            Name = "Simple Moving Average Example";
            Description = "Average price for the last N periods";
            ShortName = "SMA (" + Period + ":" + SourcePrice.ToString() + ")";

            // Our indicator has only one line 
            AddLineSeries("SMA", Color.Red, 1, LineStyle.Solid);

            //Indicator will be drawn directly on chart 
            SeparateWindow = false;
        }

        /// <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>
        protected override void OnInit()
        {

        }

        /// <summary>
        /// Calculation entry point. This function is called when a price data updates. 
        /// Will be runing under the HistoricalBar mode during history loading. 
        /// Under NewTick during realtime. 
        /// Under NewBar if start of the new bar is required.
        /// </summary>
        /// <param name="args">Provides data of updating reason and incoming price.</param>
        protected override void OnUpdate(UpdateArgs args)
        {
            // Checking, if current amount of bars
            // more, than period of moving average. If it is
            // then the calculation is possible
            if (Count <= Period)
                return;

            double sum = 0.0; // Sum of prices
            for (int i = 0; i < Period; i++)
                // Adding bar's price to the sum
                sum += GetPrice(SourcePrice, i);

            // Set value to the "SMA" line buffer.
            SetValue(sum / Period);
        }
    }
}
PreviousTrading operations

Last updated 5 years ago

Was this helpful?