Перейти к основному содержимому
Перейти к основному содержимому

quantileExactLow

quantileExactLow

Добавлена в версии v20.8

Аналогично функции quantileExact, эта функция вычисляет точный квантиль последовательности числовых данных.

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

Возвращаемое значение зависит от уровня квантиля и количества элементов в выборке, то есть если уровень равен 0.5, функция возвращает нижнее медианное значение для чётного числа элементов и центральное медианное значение для нечётного числа элементов. Медиана вычисляется аналогично реализации median_low, которая используется в Python.

Для всех остальных уровней возвращается элемент по индексу, соответствующему значению level * size_of_array.

При использовании нескольких функций quantile* с различными уровнями в одном запросе их внутренние состояния не объединяются между собой, поэтому такой запрос работает менее эффективно, чем мог бы. В этом случае используйте функцию quantiles.

Синтаксис

quantileExactLow(level)(expr)

Псевдонимы: medianExactLow

Параметры

  • level — Необязательный параметр. Уровень квантиля. Константное число с плавающей запятой от 0 до 1. Рекомендуется использовать значение level в диапазоне [0.01, 0.99]. Значение по умолчанию: 0.5. При level=0.5 функция вычисляет медиану. Float*

Аргументы

  • expr — Выражение над значениями столбца, в результате которого получаются числовые типы данных, Date или DateTime. (U)Int* или Float* или Decimal* или Date или DateTime

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

Возвращает квантиль указанного уровня. Float64 или Date или DateTime

Примеры

Вычисление точного нижнего квантиля

SELECT quantileExactLow(number) FROM numbers(10);
┌─quantileExactLow(number)─┐
│                        4 │
└──────────────────────────┘

Вычисление квантиля для заданного уровня

SELECT quantileExactLow(0.1)(number) FROM numbers(10);
┌─quantileExactLow(0.1)(number)─┐
│                             1 │
└───────────────────────────────┘