quantileExactExclusive
quantileExactExclusive
Введена в: v20.1
Аналогично функции quantileExact, эта функция вычисляет точный квантиль числовой последовательности данных.
Эта функция эквивалентна quantileExact, но использует эксклюзивный метод вычисления квантилей, как описано в методе R-6.
При использовании этой функции квантиль вычисляется таким образом, что интерполяционная формула для заданного квантиля 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.
Синтаксис
Параметры
level— Уровень квантиля. Константа с плавающей запятой от 0 до 1 (не включая сами границы). Рекомендуется использовать значениеlevelв диапазоне(0.01, 0.99).Float*
Аргументы
expr— Выражение над значениями столбца, дающее на выходе числовые типы данных, Date или DateTime.(U)Int*илиFloat*илиDecimal*илиDateилиDateTime
Возвращаемое значение
Возвращает квантиль указанного уровня. Float64
Примеры
Вычисление точного эксклюзивного квантиля
Вычисление квантилей для нескольких уровней