Documentation

tripleEMA() function

tripleEMA() returns the triple exponential moving average (TEMA) of values in the _value column.

tripleEMA uses n number of points to calculate the TEMA, giving more weight to recent data with less lag than exponentialMovingAverage() and doubleEMA().

Triple exponential moving average rules

  • A triple exponential moving average is defined as tripleEMA = (3 * EMA_1) - (3 * EMA_2) + EMA_3.
    • EMA_1 is the exponential moving average of the original data.
    • EMA_2 is the exponential moving average of EMA_1.
    • EMA_3 is the exponential moving average of EMA_2.
  • A true triple exponential moving average requires at least requires at least 3 * n - 2 values. If not enough values exist to calculate the TEMA, it returns a NaN value.
  • tripleEMA() inherits all exponentialMovingAverage() rules.
Function type signature
(<-tables: stream[{A with _value: B}], n: int) => stream[C] where B: Numeric, C: Record

For more information, see Function type signatures.

Parameters

n

(Required) Number of points to use in the calculation.

tables

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

Examples

Calculate a three point triple exponential moving average

import "sampledata"

sampledata.int()
    |> tripleEMA(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