Categories:

Aggregate Functions (Percentile Estimation) , Window Functions

# APPROX_PERCENTILE_ESTIMATE¶

Returns the desired approximated percentile value for the specified t-Digest state.

A t-Digest state produced by APPROX_PERCENTILE_ACCUMULATE and APPROX_PERCENTILE_COMBINE can be used to compute a percentile estimate using this function.

As such, APPROX_PERCENTILE_ESTIMATE(APPROX_PERCENTILE_ACCUMULATE(…)) is equivalent to APPROX_PERCENTILE(…).

## Syntax¶

```APPROX_PERCENTILE_ESTIMATE( <state> , <percentile> )
```

## Arguments¶

`state`

An expression that contains state information generated by a call to APPROX_PERCENTILE_ACCUMULATE or APPROX_PERCENTILE_COMBINE.

`percentile`

A constant real value greater than or equal to `0.0` and less than `1.0`. This indicates the percentile (from 0 to 99.999…). E.g. The value 0.65 indicates the 65th percentile.

## Example¶

Consider a scenario where you need to approximate multiple percentile values from a given set of numbers. This can be done by creating the state and then using APPROX_PERCENTILE_ESTIMATE to calculate all the percentiles:

1. First, store the state:

```CREATE OR REPLACE TABLE resultstate AS (SELECT APPROX_PERCENTILE_ACCUMULATE(c1) s FROM TABLE testtable);
```
2. Then, query the state for multiple percentiles:

```SELECT APPROX_PERCENTILE_ESTIMATE(s , 0.01),
APPROX_PERCENTILE_ESTIMATE(s , 0.15),
APPROX_PERCENTILE_ESTIMATE(s , 0.845)
FROM testtable;
```

For a more extensive example, see the Examples section in APPROX_PERCENTILE_ACCUMULATE. 