quantileExactHigh
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
Примеры
Вычисление точного верхнего квантиля
Query
Response
Query
Response