19 namespace CUDF_EXPORT
cudf {
52 class expression_parser;
53 class expression_transformer;
77 virtual std::reference_wrapper<expression const>
accept(
78 detail::expression_transformer& visitor)
const = 0;
86 [[nodiscard]]
virtual std::unique_ptr<cudf::detail::row_ir::node>
accept(
87 cudf::detail::row_ir::ast_converter& visitor)
const = 0;
98 return may_evaluate_null(left, left, stream);
138 template <
typename T>
139 __device__ T
const value() const noexcept
141 if constexpr (std::is_same_v<T, cudf::string_view>) {
142 return string_view(
static_cast<char const*
>(_data), _size);
144 if constexpr (cudf::is_fixed_point<T>()) {
145 using rep_type =
typename T::rep;
146 auto const rep = *
static_cast<rep_type const*
>(_data);
150 return *
static_cast<T const*
>(_data);
157 template <
typename T>
167 template <
typename T>
177 template <
typename T>
196 template <
typename T>
215 :
cudf::detail::scalar_device_view_base(type,
is_valid), _data(data)
228 :
cudf::detail::scalar_device_view_base(type,
is_valid), _data(data), _size(size)
244 template <
typename T>
255 template <
typename T>
266 template <
typename T>
283 template <
typename T>
317 std::reference_wrapper<expression const>
accept(
318 detail::expression_transformer& visitor)
const override;
323 [[nodiscard]] std::unique_ptr<cudf::detail::row_ir::node>
accept(
324 cudf::detail::row_ir::ast_converter& visitor)
const override;
363 : column_index(column_index), table_source(table_source)
389 return table.column(get_column_index()).type();
402 auto const table = [&] {
403 if (get_table_source() == table_reference::LEFT) {
405 }
else if (get_table_source() == table_reference::RIGHT) {
408 CUDF_FAIL(
"Column reference data type cannot be determined from unknown table.");
411 return table.column(get_column_index()).type();
422 std::reference_wrapper<expression const>
accept(
423 detail::expression_transformer& visitor)
const override;
429 return (table_source == table_reference::LEFT ? left : right).column(column_index).has_nulls();
435 [[nodiscard]] std::unique_ptr<cudf::detail::row_ir::node>
accept(
436 cudf::detail::row_ir::ast_converter& visitor)
const override;
484 [[nodiscard]] std::vector<std::reference_wrapper<expression const>>
const&
get_operands()
const
497 std::reference_wrapper<expression const>
accept(
498 detail::expression_transformer& visitor)
const override;
507 [[nodiscard]] std::unique_ptr<cudf::detail::row_ir::node>
accept(
508 cudf::detail::row_ir::ast_converter& visitor)
const override;
512 std::vector<std::reference_wrapper<expression const>> operands;
537 std::reference_wrapper<expression const>
accept(
538 detail::expression_transformer& visitor)
const override;
547 [[nodiscard]] std::unique_ptr<cudf::detail::row_ir::node>
accept(
548 cudf::detail::row_ir::ast_converter& visitor)
const override;
557 std::reference_wrapper<expression const> source_;
590 std::reference_wrapper<expression const>
accept(
591 detail::expression_transformer& visitor)
const override;
603 [[nodiscard]] std::unique_ptr<cudf::detail::row_ir::node>
accept(
604 cudf::detail::row_ir::ast_converter& visitor)
const override;
607 std::string column_name;
636 tree& operator=(
tree const&) =
delete;
643 template <
typename Expr,
typename... Args>
644 std::enable_if_t<std::is_base_of_v<expression, Expr>, Expr
const&>
emplace(Args&&... args)
646 auto expr = std::make_unique<Expr>(std::forward<Args>(args)...);
647 Expr
const& expr_ref = *expr;
648 expressions.emplace_back(std::move(expr));
657 template <
typename Expr>
658 decltype(
auto) push(Expr expr)
660 return emplace<Expr>(std::move(expr));
679 [[nodiscard]]
size_t size()
const {
return expressions.size(); }
698 std::vector<std::unique_ptr<expression>> expressions;
A expression referring to data from a column in a table.
cudf::size_type accept(detail::expression_parser &visitor) const override
Accepts a visitor class.
bool may_evaluate_null(table_view const &left, table_view const &right, rmm::cuda_stream_view stream) const override
Returns true if the expression may evaluate to null.
std::unique_ptr< cudf::detail::row_ir::node > accept(cudf::detail::row_ir::ast_converter &visitor) const override
Accepts a visitor class.
std::string get_column_name() const
Get the column name.
std::reference_wrapper< expression const > accept(detail::expression_transformer &visitor) const override
Accepts a visitor class.
column_name_reference(std::string column_name)
Construct a new column name reference object.
A expression referring to data from a column in a table.
bool may_evaluate_null(table_view const &left, table_view const &right, rmm::cuda_stream_view stream) const override
Returns true if the expression may evaluate to null.
cudf::data_type get_data_type(table_view const &left_table, table_view const &right_table) const
Get the data type.
std::unique_ptr< cudf::detail::row_ir::node > accept(cudf::detail::row_ir::ast_converter &visitor) const override
Accepts a visitor class.
cudf::size_type accept(detail::expression_parser &visitor) const override
Accepts a visitor class.
cudf::data_type get_data_type(table_view const &table) const
Get the data type.
std::reference_wrapper< expression const > accept(detail::expression_transformer &visitor) const override
Accepts a visitor class.
table_reference get_table_source() const
Get the table source.
column_reference(cudf::size_type column_index, table_reference table_source=table_reference::LEFT)
Construct a new column reference object.
cudf::size_type get_column_index() const
Get the column index.
An expression that represents a filter predicate.
std::reference_wrapper< expression const > accept(detail::expression_transformer &visitor) const override
Accepts a visitor class.
filter_predicate(expression const &source)
Construct a new filter predicate object.
cudf::size_type accept(detail::expression_parser &visitor) const override
Accepts a visitor class.
bool may_evaluate_null(table_view const &left, table_view const &right, rmm::cuda_stream_view stream) const override
Returns true if the expression may evaluate to null.
expression const & get_operand() const
Get the operand expression.
std::unique_ptr< cudf::detail::row_ir::node > accept(cudf::detail::row_ir::ast_converter &visitor) const override
Accepts a visitor class.
A type-erased scalar_device_view where the value is a fixed width type or a string.
generic_scalar_device_view(duration_scalar< T > &s)
Construct a new generic scalar device view object from a duration scalar.
generic_scalar_device_view(cudf::fixed_point_scalar< T > &s)
Construct a new generic scalar device view object from a fixed-point scalar.
generic_scalar_device_view(data_type type, void const *data, bool *is_valid)
Construct a new fixed width scalar device view object.
generic_scalar_device_view(string_scalar &s)
Construct a new generic scalar device view object from a string scalar.
generic_scalar_device_view(timestamp_scalar< T > &s)
Construct a new generic scalar device view object from a timestamp scalar.
generic_scalar_device_view(data_type type, void const *data, bool *is_valid, size_type size)
Construct a new string scalar device view object.
T const value() const noexcept
Returns the stored value.
generic_scalar_device_view(numeric_scalar< T > &s)
Construct a new generic scalar device view object from a numeric scalar.
A literal value used in an abstract syntax tree.
literal(cudf::numeric_scalar< T > &value)
Construct a new literal object.
std::unique_ptr< cudf::detail::row_ir::node > accept(cudf::detail::row_ir::ast_converter &visitor) const override
Accepts a visitor class.
cudf::size_type accept(detail::expression_parser &visitor) const override
Accepts a visitor class.
generic_scalar_device_view get_value() const
Get the value object.
cudf::data_type get_data_type() const
Get the data type.
literal(cudf::string_scalar &value)
Construct a new literal object.
cudf::scalar const & get_scalar() const
Get the scalar.
literal(cudf::duration_scalar< T > &value)
Construct a new literal object.
bool is_valid(rmm::cuda_stream_view stream) const
Check if the underlying scalar is valid.
std::reference_wrapper< expression const > accept(detail::expression_transformer &visitor) const override
Accepts a visitor class.
bool may_evaluate_null(table_view const &left, table_view const &right, rmm::cuda_stream_view stream) const override
Returns true if the expression may evaluate to null.
literal(cudf::fixed_point_scalar< T > &value)
Construct a new literal object.
literal(cudf::timestamp_scalar< T > &value)
Construct a new literal object.
An operation expression holds an operator and zero or more operands.
std::unique_ptr< cudf::detail::row_ir::node > accept(cudf::detail::row_ir::ast_converter &visitor) const override
Accepts a visitor class.
bool may_evaluate_null(table_view const &left, table_view const &right, rmm::cuda_stream_view stream) const override
Returns true if the expression may evaluate to null.
std::vector< std::reference_wrapper< expression const > > const & get_operands() const
Get the operands.
ast_operator get_operator() const
Get the operator.
operation(ast_operator op, expression const &left, expression const &right)
Construct a new binary operation object.
std::reference_wrapper< expression const > accept(detail::expression_transformer &visitor) const override
Accepts a visitor class.
operation(ast_operator op, expression const &input)
Construct a new unary operation object.
cudf::size_type accept(detail::expression_parser &visitor) const override
Accepts a visitor class.
An AST expression tree. It owns and contains multiple dependent expressions. All the expressions are ...
tree(tree &&)=default
Moves the ast tree.
tree & operator=(tree &&)=default
move-assigns the AST tree
size_t size() const
get the number of expressions added to the tree
std::enable_if_t< std::is_base_of_v< expression, Expr >, Expr const & > emplace(Args &&... args)
Add an expression to the AST tree.
tree()=default
construct an empty ast tree
expression const & front() const
get the first expression in the tree
expression const & at(size_t index)
get the expression at an index in the tree. Index is checked.
expression const & back() const
get the last expression in the tree
expression const & operator[](size_t index) const
get the expression at an index in the tree. Index is unchecked.
Indicator for the logical data type of an element in a column.
A non-owning view of scalar from device that is trivially copyable and usable in CUDA device code.
An owning class to represent a duration value in device memory.
An owning class to represent a fixed_point number in device memory.
An owning class to represent a numerical value in device memory.
An owning class to represent a singular value.
bool is_valid(rmm::cuda_stream_view stream=cudf::get_default_stream()) const
Indicates whether the scalar contains a valid value.
An owning class to represent a string in device memory.
A non-owning, immutable view of device data that is a variable length char array representing a UTF-8...
A set of cudf::column_view's of the same size.
A set of cudf::column's of the same size.
An owning class to represent a timestamp value in device memory.
Class definition for fixed point data type.
table_reference
Enum of table references.
ast_operator
Enum of supported operators.
@ RIGHT
Column index in the right table.
@ OUTPUT
Column index in the output table.
@ LEFT
Column index in the left table.
scale_type
The scale type for fixed_point.
#define CUDF_FAIL(...)
Indicates that an erroneous code path has been taken.
int32_t size_type
Row index type for columns and tables.
Class definitions for cudf::scalar.
Scalar device view class definitions.
A generic expression that can be evaluated to return a value.
virtual std::unique_ptr< cudf::detail::row_ir::node > accept(cudf::detail::row_ir::ast_converter &visitor) const =0
Accepts an row_ir::ast_converter class.
bool may_evaluate_null(table_view const &left, rmm::cuda_stream_view stream) const
Returns true if the expression may evaluate to null.
virtual cudf::size_type accept(detail::expression_parser &visitor) const =0
Accepts a visitor class.
virtual std::reference_wrapper< expression const > accept(detail::expression_transformer &visitor) const =0
Accepts a visitor class.
virtual bool may_evaluate_null(table_view const &left, table_view const &right, rmm::cuda_stream_view stream) const =0
Returns true if the expression may evaluate to null.
Helper struct for constructing fixed_point when value is already shifted.
Class definitions for (mutable)_table_view
Type declarations for libcudf.