quantileExactHigh
quantileExactHigh
Введена в версии v20.8
Подобно функции quantileExact, эта функция вычисляет точный квантиль числовой последовательности данных.
Для получения точного значения все переданные значения объединяются в массив, который затем полностью сортируется.
Сложность алгоритма сортировки равна O(N·log(N)), где N = std::distance(first, last) сравнений.
Возвращаемое значение зависит от уровня квантиля и количества элементов в выборке, то есть если уровень равен 0.5, то функция возвращает большее из двух средних значений для чётного числа элементов и средний (центральный) элемент для нечётного числа элементов.
Медиана вычисляется аналогично реализации median_high, которая используется в Python.
Для всех остальных уровней возвращается элемент с индексом, соответствующим значению level * size_of_array.
При использовании нескольких функций quantile* с разными уровнями в одном запросе их внутренние состояния не объединяются (то есть запрос работает менее эффективно, чем мог бы).
В таком случае используйте функцию quantiles.
Синтаксис
Псевдонимы: medianExactHigh
Параметры
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
Примеры
Вычисление точного верхнего квантиля
Вычисление квантиля для заданного уровня