14 #include <cuda/std/type_traits>
16 namespace CUDF_EXPORT
cudf {
25 template <
typename...>
39 #define CUDF_ENABLE_IF(...) cuda::std::enable_if_t<(__VA_ARGS__)>* = nullptr
42 template <
typename L,
typename R>
43 using less_comparable = decltype(cuda::std::declval<L>() < cuda::std::declval<R>());
46 template <
typename L,
typename R>
50 template <
typename L,
typename R>
54 template <
typename L,
typename R,
typename =
void>
55 struct is_relationally_comparable_impl : cuda::std::false_type {};
57 template <
typename L,
typename R>
58 struct is_relationally_comparable_impl<L,
60 void_t<less_comparable<L, R>, greater_comparable<L, R>>>
61 : cuda::std::true_type {};
63 template <
typename L,
typename R,
typename =
void>
64 struct is_equality_comparable_impl : cuda::std::false_type {};
66 template <
typename L,
typename R>
71 template <
typename AlwaysVoid,
typename... Ts>
72 struct has_common_type_impl : cuda::std::false_type {};
74 template <
typename... Ts>
75 struct has_common_type_impl<
void_t<cuda::std::common_type_t<Ts...>>, Ts...> : cuda::std::true_type {
80 template <
typename... Ts>
84 template <
typename... Ts>
89 using is_timestamp_t = cuda::std::disjunction<cuda::std::is_same<cudf::timestamp_D, T>,
90 cuda::std::is_same<cudf::timestamp_h, T>,
91 cuda::std::is_same<cudf::timestamp_m, T>,
92 cuda::std::is_same<cudf::timestamp_s, T>,
93 cuda::std::is_same<cudf::timestamp_ms, T>,
94 cuda::std::is_same<cudf::timestamp_us, T>,
95 cuda::std::is_same<cudf::timestamp_ns, T>>;
99 using is_duration_t = cuda::std::disjunction<cuda::std::is_same<cudf::duration_D, T>,
100 cuda::std::is_same<cudf::duration_h, T>,
101 cuda::std::is_same<cudf::duration_m, T>,
102 cuda::std::is_same<cudf::duration_s, T>,
103 cuda::std::is_same<cudf::duration_ms, T>,
104 cuda::std::is_same<cudf::duration_us, T>,
105 cuda::std::is_same<cudf::duration_ns, T>>;
119 template <
typename L,
typename R>
122 return detail::is_relationally_comparable_impl<L, R>::value;
146 template <
typename L,
typename R>
149 return detail::is_equality_comparable_impl<L, R>::value;
168 template <
typename T>
171 return cuda::std::is_arithmetic<T>();
198 template <
typename T>
201 return cuda::std::is_integral_v<T> and not cuda::std::is_same_v<T, bool>;
223 template <
typename T>
226 return cuda::std::is_signed_v<T>;
247 template <
typename T>
250 return cuda::std::is_unsigned_v<T>;
270 template <
typename Iterator>
273 return cuda::std::is_signed_v<typename cuda::std::iterator_traits<Iterator>::value_type>;
283 template <
typename T>
286 return cuda::std::is_integral_v<T>;
307 template <
typename T>
310 return cuda::std::is_integral_v<T> and not cuda::std::is_same_v<T, bool>;
331 template <
typename T>
334 return cudf::is_numeric<T>() and not cuda::std::is_same_v<T, bool>;
355 template <
typename T>
358 return cuda::std::is_floating_point_v<T>;
379 template <
typename T>
382 return cuda::std::is_same_v<cuda::std::remove_cv_t<T>, std::byte>;
392 template <
typename T>
395 return cuda::std::is_same_v<T, bool>;
414 template <
typename T>
438 template <
typename T>
441 return cuda::std::is_same_v<numeric::decimal32, T> ||
442 cuda::std::is_same_v<numeric::decimal64, T> ||
443 cuda::std::is_same_v<numeric::decimal128, T> ||
444 cuda::std::is_same_v<numeric::fixed_point<int32_t, numeric::Radix::BASE_2>, T> ||
445 cuda::std::is_same_v<numeric::fixed_point<int64_t, numeric::Radix::BASE_2>, T> ||
446 cuda::std::is_same_v<numeric::fixed_point<__int128_t, numeric::Radix::BASE_2>, T>;
465 template <
typename T>
489 template <
typename T>
492 return is_duration<T>() || is_timestamp<T>();
519 template <
typename T>
522 return cudf::is_numeric<T>() or cudf::is_chrono<T>() or cudf::is_boolean<T>() or
533 template <
typename T>
536 return cuda::std::is_same_v<dictionary32, T>;
557 template <
typename T>
562 return cudf::is_numeric<T>() || cudf::is_chrono<T>() || cudf::is_fixed_point<T>();
590 template <
typename T>
593 return cuda::std::is_same_v<T, cudf::string_view> or
594 cuda::std::is_same_v<T, cudf::dictionary32> or cuda::std::is_same_v<T, cudf::list_view> or
595 cuda::std::is_same_v<T, cudf::struct_view>;
623 template <
typename T>
626 return cuda::std::is_same_v<T, cudf::list_view> || cuda::std::is_same_v<T, cudf::struct_view>;
657 template <
typename From,
typename To>
662 template <
typename Duration1,
typename Duration2>
664 : cuda::std::is_convertible<typename cudf::detail::time_point<Duration1>::duration,
665 typename cudf::detail::time_point<Duration2>::duration> {};
Indicator for the logical data type of an element in a column.
A non-owning, immutable view of device data that is a variable length char array representing a UTF-8...
Concrete type definition for dictionary columns.
Concrete type definitions for int32_t and int64_t durations in varying resolutions.
Class definition for fixed point data type.
bool is_dictionary(data_type type)
Indicates whether type is a dictionary data_type.
constexpr bool is_byte()
Indicates whether T is a std::byte type.
bool is_duration(data_type type)
Indicates whether type is a duration data_type.
bool is_numeric(data_type type)
Indicates whether type is a numeric data_type.
bool is_integral(data_type type)
Indicates whether type is a integral data_type.
typename detail::has_common_type_impl< void, Ts... >::type has_common_type
Checks if types have a common type.
bool is_equality_comparable(data_type type)
Checks whether data_type type supports equality comparisons.
bool is_index_type(data_type type)
Indicates whether the type type is a index type.
decltype(cuda::std::declval< L >() > cuda::std::declval< R >()) greater_comparable
Checks if two types are comparable using greater operator (i.e. >).
bool is_numeric_not_bool(data_type type)
Indicates whether type is a numeric data_type but not BOOL8.
bool is_relationally_comparable(data_type type)
Checks whether data_type type supports relational comparisons.
decltype(cuda::std::declval< L >()==cuda::std::declval< R >()) equality_comparable
Checks if two types are comparable using equality operator (i.e. ==).
cuda::std::disjunction< cuda::std::is_same< cudf::duration_D, T >, cuda::std::is_same< cudf::duration_h, T >, cuda::std::is_same< cudf::duration_m, T >, cuda::std::is_same< cudf::duration_s, T >, cuda::std::is_same< cudf::duration_ms, T >, cuda::std::is_same< cudf::duration_us, T >, cuda::std::is_same< cudf::duration_ns, T > > is_duration_t
Checks if a type is a duration type.
bool is_boolean(data_type type)
Indicates whether type is a Boolean data_type.
bool is_bit_castable(data_type from, data_type to)
Indicates whether from is bit-castable to to.
bool is_compound(data_type type)
Indicates whether elements of type are compound.
constexpr bool is_rep_layout_compatible()
Indicates whether T is layout compatible with its "representation" type.
bool is_signed(data_type type)
Indicates whether type is a signed numeric data_type.
bool is_nested(data_type type)
Indicates whether type is a nested type.
decltype(cuda::std::declval< L >()< cuda::std::declval< R >()) less_comparable
Checks if two types are comparable using less operator (i.e. <).
cuda::std::disjunction< cuda::std::is_same< cudf::timestamp_D, T >, cuda::std::is_same< cudf::timestamp_h, T >, cuda::std::is_same< cudf::timestamp_m, T >, cuda::std::is_same< cudf::timestamp_s, T >, cuda::std::is_same< cudf::timestamp_ms, T >, cuda::std::is_same< cudf::timestamp_us, T >, cuda::std::is_same< cudf::timestamp_ns, T > > is_timestamp_t
Checks if a type is a timestamp type.
void void_t
Utility metafunction that maps a sequence of any types to the type void.
bool is_timestamp(data_type type)
Indicates whether type is a timestamp data_type.
bool is_floating_point(data_type type)
Indicates whether type is a floating point data_type.
bool is_unsigned(data_type type)
Indicates whether type is a unsigned numeric data_type.
constexpr bool has_common_type_v
Helper variable template for has_common_type<>::value.
bool is_integral_not_bool(data_type type)
Indicates whether type is a integral data_type and not BOOL8.
bool is_chrono(data_type type)
Indicates whether type is a chrono data_type.
bool is_fixed_point(data_type type)
Indicates whether type is a fixed point data_type.
bool is_fixed_width(data_type type)
Indicates whether elements of type are fixed-width.
constexpr CUDF_HOST_DEVICE bool is_signed_iterator()
Indicates whether the Iterator value type is unsigned.
Concrete type definitions for int32_t and int64_t timestamps in varying resolutions as durations sinc...
time_point< Duration > timestamp
A wrapper around a column of time_point in varying resolutions.
Type declarations for libcudf.
#define CUDF_HOST_DEVICE
Indicates that the function or method is usable on host and device.