2018-09-08 22:04:39 +00:00
|
|
|
#include <Functions/FunctionNumericPredicate.h>
|
|
|
|
#include <Functions/FunctionFactory.h>
|
2021-10-02 07:13:14 +00:00
|
|
|
#include <base/bit_cast.h>
|
2018-09-08 22:04:39 +00:00
|
|
|
#include <type_traits>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
2020-09-07 18:00:37 +00:00
|
|
|
namespace
|
|
|
|
{
|
2018-09-08 22:04:39 +00:00
|
|
|
|
|
|
|
struct IsFiniteImpl
|
|
|
|
{
|
|
|
|
/// Better implementation, because isinf, isfinite, isnan are not inlined for unknown reason.
|
|
|
|
/// Assuming IEEE 754.
|
|
|
|
/// NOTE gcc 7 doesn't vectorize this loop.
|
|
|
|
|
|
|
|
static constexpr auto name = "isFinite";
|
|
|
|
template <typename T>
|
|
|
|
static bool execute(const T t)
|
|
|
|
{
|
|
|
|
if constexpr (std::is_same_v<T, float>)
|
2021-06-15 19:55:21 +00:00
|
|
|
return (bit_cast<uint32_t>(t)
|
2018-09-08 22:04:39 +00:00
|
|
|
& 0b01111111100000000000000000000000)
|
|
|
|
!= 0b01111111100000000000000000000000;
|
|
|
|
else if constexpr (std::is_same_v<T, double>)
|
2021-06-15 19:55:21 +00:00
|
|
|
return (bit_cast<uint64_t>(t)
|
2018-09-08 22:04:39 +00:00
|
|
|
& 0b0111111111110000000000000000000000000000000000000000000000000000)
|
|
|
|
!= 0b0111111111110000000000000000000000000000000000000000000000000000;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
(void)t;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
using FunctionIsFinite = FunctionNumericPredicate<IsFiniteImpl>;
|
|
|
|
|
2020-09-07 18:00:37 +00:00
|
|
|
}
|
2018-09-08 22:04:39 +00:00
|
|
|
|
2022-07-04 07:01:39 +00:00
|
|
|
REGISTER_FUNCTION(IsFinite)
|
2018-09-08 22:04:39 +00:00
|
|
|
{
|
|
|
|
factory.registerFunction<FunctionIsFinite>();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|