-
Notifications
You must be signed in to change notification settings - Fork 921
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Expose stream-ordering in scalar and avro APIs #17766
base: branch-25.02
Are you sure you want to change the base?
Conversation
Auto-sync is disabled for draft pull requests in this repository. Workflows must be run manually. Contributors can view more details about this message here. |
cpp/include/cudf/scalar/scalar.hpp
Outdated
*/ | ||
explicit operator value_type() const; | ||
T get_value(rmm::cuda_stream_view stream = cudf::get_default_stream()) const; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
RMM just calls this value
. We often try to avoid “get” in our function names.
T get_value(rmm::cuda_stream_view stream = cudf::get_default_stream()) const; | |
T value(rmm::cuda_stream_view stream = cudf::get_default_stream()) const; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wait, doesn’t value
already exist just below here? We may not need get_value
at all. Maybe we just need to delete the conversion operator since it does not take a stream.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good point - I chose to introduce another function here because value
can return either host or device data depending on the type. string_scalar::value
returns a cudf::string_view
on the device, while fixed_point::value
and fixed_width::value
copy to host. I was also unsure of using fixed_point::value
directly since the conversion operator returns the fixed_point_value
instead of the unscaled value.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm hesitant to modify string_scalar::value
to return a host string view since it is used in several places that directly access the scalar on device. One option is to rename this function to string_scalar::d_value
and introduce another string_scalar::value
that returns a std::string
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The string_scalar::value()
should return a cudf::string_view
which is possible from host or device since it just wraps a pointer and a size held by the string_scalar
. No device code is needed. Actually the stream
parameter is not used at all.
To return a host std::string
one would use the string_scalar::to_string()
function.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with Bradley we should not have the get_value()
functions and just keep the value()
ones.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks David, Bradley. I've retained the value
functions and got rid of the conversion operators.
cpp/tests/binaryop/assert-binops.h
Outdated
@@ -81,7 +81,7 @@ void ASSERT_BINOP(cudf::column_view const& out, | |||
TypeOp&& op, | |||
ValueComparator const& value_comparator = ValueComparator()) | |||
{ | |||
auto lhs_h = static_cast<ScalarType const&>(lhs).operator TypeLhs(); | |||
auto lhs_h = static_cast<ScalarType const&>(lhs).get_value(cudf::get_default_stream()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please refactor the tests like this:
auto lhs_h = static_cast<ScalarType const&>(lhs).get_value(cudf::get_default_stream()); | |
auto lhs_h = static_cast<ScalarType const&>(lhs).value(cudf::get_default_stream()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've added a scalar_host_value
function that checks which scalar class is passed since the conversion operator in string_scalar
and fixed_point_scalar
called to_string
and fixed_point_value
respectively.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One style request, otherwise LGTM!
if constexpr (std::is_same_v<ScalarType, cudf::string_scalar>) | ||
return sclr.to_string(stream); | ||
else if constexpr (std::is_same_v<ScalarType, cudf::fixed_point_scalar<TypeLhs>>) | ||
return sclr.fixed_point_value(stream); | ||
else | ||
return sclr.value(stream); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please always use braces for readability.
if constexpr (std::is_same_v<ScalarType, cudf::string_scalar>) | |
return sclr.to_string(stream); | |
else if constexpr (std::is_same_v<ScalarType, cudf::fixed_point_scalar<TypeLhs>>) | |
return sclr.fixed_point_value(stream); | |
else | |
return sclr.value(stream); | |
if constexpr (std::is_same_v<ScalarType, cudf::string_scalar>) { | |
return sclr.to_string(stream); | |
} else if constexpr (std::is_same_v<ScalarType, cudf::fixed_point_scalar<TypeLhs>>) { | |
return sclr.fixed_point_value(stream); | |
} else { | |
return sclr.value(stream); | |
} |
Description
Contributes to #13744
Replaces conversion operators in derived classes of
cudf::scalar
with stream-orderedget_value(stream)
member function.Adds stream parameter to
cudf::io::read_avro
Checklist