# Weighted Moving Average (WMA)

Weighted Moving Average (WMA) is a moving average indicator very similar to SMA but, as with EMA, it adds more weight to recent data points. What sets it apart, however, is that WMA doesn’t include data in its formula that comes from periods older than the selected range.

### **Trading application**

WMA is a line which is shown within the price graph, moving close to the price and eventually intersecting with it. WMA moving above the price indicates a downtrend while WMA moving below the price indicates an uptrend. It can also act as a level of Support/Resistance in uptrends and downtrends, respectively. We can interpret buy/sell signals using 2 different SMA lines (one with a shorter period than the other).

If the shorter WMA (e.g. a 20 day WMA) crosses upwards over the longer WMA (e.g. 50 days), it is a buy signal. The opposite, where a shorter WMA crosses downwards below the longer WMA, indicates a sell signal. Another interpretation arises when intersecting with the price. A shorter WMA crossing the price from the bottom up, while it remains above the longer WMA, is considered a buy signal, in the same way that the shorter WMA crossing the price from above downwards, while the longer WMA is located above the shorter WMA, indicates a sell signal.

### **Calculation**

$$
WMA = (P(1) \* 5) + (P(2) \* 4) + (P(3) \* 3) + (P(4) \* 2) + (P(5)\* 1) / (5 + 4+ 3 + 2 + 1)
$$

*P(n): Closing price from n period*

{% hint style="info" %}
The above calculation was limited to the 5 most recent periods as a matter of simplicity
{% endhint %}

### **Parameters**

#### Input Parameters

| Name     | Type | Range of value    | Description                             |
| -------- | ---- | ----------------- | --------------------------------------- |
| `period` | int  | <1, int.MaxValue> | Number of bars used in the calculation. |

#### Output Parameters

Indicator ouptuts a single value.

| Type   | Range of value       |
| ------ | -------------------- |
| double | (0, double.MaxValue) |

### Examples

```csharp
// Prints the current value of a 20 period WMA using
// the daily bars close price value.
wma = indicators.WMA(20).OnSeries(dailyBars.Close);
Log(wma.Value.ToString());

// Prints the previous value of WMA.
wma = indicators.WMA(20).Keep(2).OnSeries(dailyBars.Close);
Log(wma.Values[1].ToString());
```

#### Complete example

```csharp
using Signals.DataSeries.Bars;
using Signals.Framework;
using Signals.Indicators.WMA;

public class MyStrategy : SingleMarketStrategy
{
    private Bars dailyBars;
    private WMA wma;

    public override void Setup(DataMarketplace data, IndicatorsMarketplace indicators)
    {
        dailyBars = data.Bars(BarPeriodType.Day, 1).WithOffset(25);
        wma = indicators.WMA(20).Keep(2).OnSeries(dailyBars.Close);
    }

    public override void RegisterActions()
    {
        OnUpdateOf(dailyBars).Do(() =>
        {   
            // Prints the current WMA value
            Log("The current WMA value is " + wma.Value.ToString());

            // Prints the previour WMA value
            Log("The previous WMA value is " + wma.Values[1].ToString());
        });
    }
}
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://help.signals.network/knowledge-base/indicators/trend-analysis/weighted-moving-average-wma.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
