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

quantileExactWeighted

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

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

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

Синтаксис

quantileExactWeighted(level)(expr, weight)

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

Аргументы

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

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

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

Тип:

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

Пример

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

┌─n─┬─val─┐
│ 0 │   3 │
│ 1 │   2 │
│ 2 │   1 │
│ 5 │   4 │
└───┴─────┘

Запрос:

SELECT quantileExactWeighted(n, val) FROM t

Результат:

┌─quantileExactWeighted(n, val)─┐
│                             1 │
└───────────────────────────────┘

См. Также