# tripleExponentialDerivative() function

`tripleExponentialDerivative()` returns the triple exponential derivative (TRIX) values using `n` points.

Triple exponential derivative, commonly referred to as “TRIX,” is a momentum indicator and oscillator. A triple exponential derivative uses the natural logarithm (log) of input data to calculate a triple exponential moving average over the period of time. The calculation prevents cycles shorter than the defined period from being considered by the indicator. `tripleExponentialDerivative()` uses the time between `n` points to define the period.

Triple exponential derivative oscillates around a zero line. A positive momentum oscillator value indicates an overbought market; a negative value indicates an oversold market. A positive momentum indicator value indicates increasing momentum; a negative value indicates decreasing momentum.

#### Triple exponential moving average rules

• A triple exponential derivative is defined as:
• `TRIX[i] = ((EMA3[i] / EMA3[i - 1]) - 1) * 100`
• `EMA3 = EMA(EMA(EMA(data)))`
• If there are not enough values to calculate a triple exponential derivative, the output `_value` is `NaN`; all other columns are the same as the last record of the input table.
• The function behaves the same way as the `exponentialMovingAverage()` function:
• The function ignores `null` values.
• The function operates only on the `_value` column.
##### Function type signature
``````(<-tables: stream[{A with _value: B}], n: int) => stream[{A with _value: float}] where A: Record, B: Numeric
``````

## Parameters

### n

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

### tables

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

## Examples

### Calculate a two-point triple exponential derivative

``````import "sampledata"

sampledata.float()
|> tripleExponentialDerivative(n: 2)
``````

### Introducing InfluxDB Clustered

A highly available InfluxDB 3.0 cluster on your own infrastructure.

InfluxDB Clustered is a highly available InfluxDB 3.0 cluster built for high write and query workloads on your own infrastructure.

InfluxDB Clustered is currently in limited availability and is only available to a limited group of InfluxData customers. If interested in being part of the limited access group, please contact the InfluxData Sales team.

### The future of Flux

Flux is going into maintenance mode. You can continue using it as you currently are without any changes to your code.

Flux is going into maintenance mode and will not be supported in InfluxDB 3.0. This was a decision based on the broad demand for SQL and the continued growth and adoption of InfluxQL. We are continuing to support Flux for users in 1.x and 2.x so you can continue using it with no changes to your code. If you are interested in transitioning to InfluxDB 3.0 and want to future-proof your code, we suggest using InfluxQL.

For information about the future of Flux, see the following:

### State of the InfluxDB Cloud Serverless documentation

InfluxDB Cloud Serverless documentation is a work in progress.

The new documentation for InfluxDB Cloud Serverless is a work in progress. We are adding new information and content almost daily. Thank you for your patience!

If there is specific information you’re looking for, please submit a documentation issue.