#include #include #include namespace DB { template struct NegateImpl { using ResultType = std::conditional_t, A, typename NumberTraits::ResultOfNegate::Type>; static inline NO_SANITIZE_UNDEFINED ResultType apply(A a) { return -static_cast(a); } #if USE_EMBEDDED_COMPILER static constexpr bool compilable = true; static inline llvm::Value * compile(llvm::IRBuilder<> & b, llvm::Value * arg, bool) { return arg->getType()->isIntegerTy() ? b.CreateNeg(arg) : b.CreateFNeg(arg); } #endif }; struct NameNegate { static constexpr auto name = "negate"; }; using FunctionNegate = FunctionUnaryArithmetic; template <> struct FunctionUnaryArithmeticMonotonicity { static bool has() { return true; } static IFunction::Monotonicity get(const Field &, const Field &) { return { true, false }; } }; void registerFunctionNegate(FunctionFactory & factory) { factory.registerFunction(); } }