movingAverage() function

The movingAverage() function calculates the mean of values grouped into n number of points.

Function type: Aggregate

  n: 5,
  columns: ["_value"]
Moving average rules:
  • The average over a period populated by n values is equal to their algebraic mean.
  • The average over a period populated by only null values is null.
  • Moving averages skip null values.
  • If n is less than the number of records in a table, movingAverage returns the average of the available values.



The number of points to average.

Data type: Integer


Columns to operate on. Defaults to ["_value"].

Data type: Array of Strings


Calculate a five point moving average

from(bucket: "example-bucket"):
  |> range(start: -12h)
  |> movingAverage(n: 5)

Calculate a ten point moving average

movingAverage = (every, period, column="_value", tables=<-) =>
    |> window(every: every, period: period)
    |> mean(column: column)
    |> duplicate(column: "_stop", as: "_time")
    |> window(every: inf)

Table transformation with a two point moving average

Input table:
_time A B C D tag
0001 null 1 2 null tv
0002 6 2 null null tv
0003 4 null 4 4 tv
// ...
  |> movingAverage(
    n: 2,
    columns: ["A", "B", "C", "D"]
Output table:
_time A B C D tag
0002 6 1.5 2 null tv
0003 5 2 4 4 tv

This documentation is open source. See a typo? Please, open an issue.

Need help getting up and running? Get Support