2022-09-11 06:46:05 +00:00
|
|
|
#include <AggregateFunctions/AggregateFunctionQuantile.h>
|
|
|
|
#include <AggregateFunctions/QuantileExact.h>
|
|
|
|
#include <AggregateFunctions/AggregateFunctionFactory.h>
|
|
|
|
#include <AggregateFunctions/Helpers.h>
|
|
|
|
#include <DataTypes/DataTypeDate.h>
|
|
|
|
#include <DataTypes/DataTypeDateTime.h>
|
|
|
|
#include <Core/Field.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
struct Settings;
|
|
|
|
|
|
|
|
namespace ErrorCodes
|
|
|
|
{
|
2024-05-06 09:35:48 +00:00
|
|
|
extern const int TOO_FEW_ARGUMENTS_FOR_FUNCTION;
|
2022-09-11 06:46:05 +00:00
|
|
|
extern const int ILLEGAL_TYPE_OF_ARGUMENT;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
|
2023-11-06 04:53:16 +00:00
|
|
|
template <typename Value, bool _> using FuncQuantileExactInclusive = AggregateFunctionQuantile<Value, QuantileExactInclusive<Value>, NameQuantileExactInclusive, false, Float64, false, false>;
|
|
|
|
template <typename Value, bool _> using FuncQuantilesExactInclusive = AggregateFunctionQuantile<Value, QuantileExactInclusive<Value>, NameQuantilesExactInclusive, false, Float64, true, false>;
|
2022-09-11 06:46:05 +00:00
|
|
|
|
|
|
|
template <template <typename, bool> class Function>
|
|
|
|
AggregateFunctionPtr createAggregateFunctionQuantile(
|
|
|
|
const std::string & name, const DataTypes & argument_types, const Array & params, const Settings *)
|
|
|
|
{
|
2024-03-23 03:21:06 +00:00
|
|
|
if (argument_types.empty())
|
2024-05-06 09:35:48 +00:00
|
|
|
throw Exception(ErrorCodes::TOO_FEW_ARGUMENTS_FOR_FUNCTION, "Aggregate function {} requires at least one argument", name);
|
2024-03-23 03:21:06 +00:00
|
|
|
|
2022-09-11 06:46:05 +00:00
|
|
|
const DataTypePtr & argument_type = argument_types[0];
|
|
|
|
WhichDataType which(argument_type);
|
|
|
|
|
|
|
|
#define DISPATCH(TYPE) \
|
|
|
|
if (which.idx == TypeIndex::TYPE) return std::make_shared<Function<TYPE, true>>(argument_types, params);
|
|
|
|
FOR_BASIC_NUMERIC_TYPES(DISPATCH)
|
|
|
|
#undef DISPATCH
|
|
|
|
if (which.idx == TypeIndex::Date) return std::make_shared<Function<DataTypeDate::FieldType, false>>(argument_types, params);
|
|
|
|
if (which.idx == TypeIndex::DateTime) return std::make_shared<Function<DataTypeDateTime::FieldType, false>>(argument_types, params);
|
|
|
|
|
2023-01-23 21:13:58 +00:00
|
|
|
throw Exception(ErrorCodes::ILLEGAL_TYPE_OF_ARGUMENT, "Illegal type {} of argument for aggregate function {}",
|
|
|
|
argument_type->getName(), name);
|
2022-09-11 06:46:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-09-11 07:29:24 +00:00
|
|
|
void registerAggregateFunctionsQuantileExactInclusive(AggregateFunctionFactory & factory)
|
2022-09-11 06:46:05 +00:00
|
|
|
{
|
|
|
|
/// For aggregate functions returning array we cannot return NULL on empty set.
|
|
|
|
AggregateFunctionProperties properties = { .returns_default_when_only_null = true };
|
|
|
|
|
|
|
|
factory.registerFunction(NameQuantileExactInclusive::name, createAggregateFunctionQuantile<FuncQuantileExactInclusive>);
|
|
|
|
factory.registerFunction(NameQuantilesExactInclusive::name, { createAggregateFunctionQuantile<FuncQuantilesExactInclusive>, properties });
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|