quantileTDigestWeighted
quantileTDigestWeighted
Введена в: v20.1
Вычисляет приближенный квантиль числовой последовательности с использованием алгоритма t-digest. Функция учитывает вес каждого элемента последовательности.
Максимальная погрешность составляет 1%.
Потребление памяти — log(n), где n — количество значений.
Производительность функции ниже, чем у quantile или quantileTiming.
С точки зрения соотношения размера State к точности эта функция значительно лучше, чем quantile.
Результат зависит от порядка выполнения запроса и недетерминирован.
При использовании нескольких функций quantile* с разными уровнями в одном запросе внутренние состояния не объединяются (то есть запрос работает менее эффективно, чем мог бы).
В этом случае используйте функцию quantiles.
Использование quantileTDigestWeighted не рекомендуется для очень маленьких наборов данных и может приводить к значительной погрешности.
В этом случае рассмотрите возможность использования quantileTDigest вместо нее.
Синтаксис
Псевдонимы: medianTDigestWeighted
Параметры
level— Необязательный параметр. Уровень квантиля. Константное число с плавающей запятой от 0 до 1. Рекомендуется использовать значениеlevelв диапазоне[0.01, 0.99]. Значение по умолчанию: 0.5. Приlevel=0.5функция вычисляет медиану.Float*
Аргументы
expr— Выражение над значениями столбца, результатом которого являются числовые типы данных, Date или DateTime.(U)Int*илиFloat*илиDecimal*илиDateилиDateTimeweight— Столбец с весами элементов последовательности. Вес — это количество вхождений значения.UInt*
Возвращаемое значение
Приближённый квантиль указанного уровня. Float64 или Date или DateTime
Примеры
Вычисление взвешенного квантиля с t-digest
См. также