Documentation

exponentialMovingAverage() function

exponentialMovingAverage() calculates the exponential moving average of n number of values in the _value column giving more weight to more recent data.

Exponential moving average rules

  • The first value of an exponential moving average over n values is the algebraic mean of n values.
  • Subsequent values are calculated as y(t) = x(t) * k + y(t-1) * (1 - k), where:
    • y(t) is the exponential moving average at time t.
    • x(t) is the value at time t.
    • k = 2 / (1 + n).
  • The average over a period populated by only null values is null.
  • Exponential moving averages skip null values.
Function type signature
(<-tables: stream[{A with _value: B}], n: int) => stream[{A with _value: B}] where B: Numeric

For more information, see Function type signatures.

Parameters

n

(Required) Number of values to average.

tables

Input data. Default is piped-forward data (<-).

Examples

Calculate a three point exponential moving average

import "sampledata"

sampledata.int()
    |> exponentialMovingAverage(n: 3)

View example input and output

Calculate a three point exponential moving average with null values

import "sampledata"

sampledata.int(includeNull: true)
    |> exponentialMovingAverage(n: 3)

View example input and output


Was this page helpful?

Thank you for your feedback!


New in InfluxDB 3.6

Key enhancements in InfluxDB 3.6 and the InfluxDB 3 Explorer 1.4.

See the Blog Post

InfluxDB 3.6 is now available for both Core and Enterprise. This release introduces the 1.4 update to InfluxDB 3 Explorer, featuring the beta launch of Ask AI, along with new capabilities for simple startup and expanded functionality in the Processing Engine.

For more information, check out:

InfluxDB Docker latest tag changing to InfluxDB 3 Core

On February 3, 2026, the latest tag for InfluxDB Docker images will point to InfluxDB 3 Core. To avoid unexpected upgrades, use specific version tags in your Docker deployments.

If using Docker to install and run InfluxDB, the latest tag will point to InfluxDB 3 Core. To avoid unexpected upgrades, use specific version tags in your Docker deployments. For example, if using Docker to run InfluxDB v2, replace the latest version tag with a specific version tag in your Docker pull command–for example:

docker pull influxdb:2