> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-mintlify-3a82795f.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

> Точно вычисляет квантиль числовой последовательности.

# quantileExactExclusive

<div id="quantileExactExclusive">
  ## quantileExactExclusive
</div>

Добавленный в: v20.1.0

Как и [`quantileExact`](/ru/reference/functions/aggregate-functions/quantileExact), эта функция вычисляет точную [квантиль](https://en.wikipedia.org/wiki/Quantile) числовой последовательности.

Эта функция эквивалентна [`quantileExact`](/ru/reference/functions/aggregate-functions/quantileExact), но использует эксклюзивный метод для вычисления квантилей, как описано в [методе R-6](https://en.wikipedia.org/wiki/Quantile#Estimating_quantiles_from_a_sample).

При использовании этой функции квантиль вычисляется так, что формула интерполяции для заданной квантили p имеет вид: `x[floor(n*p)] + (n*p - floor(n*p)) * (x[floor(n*p)+1] - x[floor(n*p)])`, где x — отсортированный массив.

Чтобы получить точное значение, все переданные значения объединяются в массив, который затем полностью сортируется.
Сложность алгоритма сортировки составляет `O(N·log(N))`, где `N = std::distance(first, last)`.

При использовании нескольких функций `quantile*` с разными уровнями в одном запросе их внутренние состояния не объединяются (то есть запрос работает менее эффективно, чем мог бы).
В этом случае используйте функцию [quantiles](/ru/reference/functions/aggregate-functions/quantiles).

**Синтаксис**

```sql theme={null}
quantileExactExclusive(level)(expr)
```

**Параметры**

* `level` — Уровень квантиля. Константное число с плавающей точкой от 0 до 1 (не включая границы). Рекомендуется использовать значение `level` в диапазоне `(0.01, 0.99)`. [`Float*`](/ru/reference/data-types/float)

**Аргументы**

* `expr` — Выражение по значениям столбца, возвращающее числовые типы данных, `Date` или `DateTime`. [`(U)Int*`](/ru/reference/data-types/int-uint) или [`Float*`](/ru/reference/data-types/float) или [`Decimal*`](/ru/reference/data-types/decimal) или [`Date`](/ru/reference/data-types/date) или [`DateTime`](/ru/reference/data-types/datetime)

**Возвращаемое значение**

Возвращает квантиль указанного уровня. [`Float64`](/ru/reference/data-types/float)

**Примеры**

**Вычисление точного эксклюзивного квантиля**

```sql title=Query theme={null}
SELECT quantileExactExclusive(0.25)(number) FROM numbers(5);
```

```response title=Response theme={null}
┌─quantileExactExclusive(0.25)(number)─┐
│                                  0.5 │
└──────────────────────────────────────┘
```

**Вычисление квантилей для нескольких уровней**

```sql title=Query theme={null}
SELECT quantileExactExclusive(0.1)(number), quantileExactExclusive(0.9)(number) FROM numbers(10);
```

```response title=Response theme={null}
┌─quantileExactExclusive(0.1)(number)─┬─quantileExactExclusive(0.9)(number)─┐
│                                 0.4 │                                 8.6 │
└─────────────────────────────────────┴─────────────────────────────────────┘
```
