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

quantileExactWeighted

Точно вычисляет квантиль числовой последовательности данных, учитывая вес каждого элемента.

Чтобы получить точное значение, все переданные значения комбинируются в массив, который затем частично сортируется. Каждое значение учитывается с его весом, как будто оно присутствует weight раз. В алгоритме используется хеш-таблица. Из-за этого, если переданные значения часто повторяются, функция потребляет меньше ОЗУ, чем quantileExact. Вы можете использовать эту функцию вместо quantileExact и указать вес 1.

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

Синтаксис

Псевдоним: medianExactWeighted.

Аргументы

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

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

  • Квантиль указанного уровня.

Тип:

  • Float64 для входного числового типа данных.
  • Date, если входные значения имеют тип Date.
  • DateTime, если входные значения имеют тип DateTime.

Пример

Входная таблица:

Запрос:

Результат:

См. также