From 033158d2ff4767c62a57a3dc4a7f8aebb702f344 Mon Sep 17 00:00:00 2001 From: Lawrence Mitchell Date: Thu, 15 Feb 2024 10:37:59 +0000 Subject: [PATCH] Implement cudf::stable_sort - Closes #15065 --- cpp/include/cudf/detail/sorting.hpp | 11 ++++++++++ cpp/include/cudf/sorting.hpp | 12 ++++++++++ cpp/src/sort/stable_sort.cu | 34 ++++++++++++++++++++++++++++- 3 files changed, 56 insertions(+), 1 deletion(-) diff --git a/cpp/include/cudf/detail/sorting.hpp b/cpp/include/cudf/detail/sorting.hpp index da9ae393d72..92bc4117a27 100644 --- a/cpp/include/cudf/detail/sorting.hpp +++ b/cpp/include/cudf/detail/sorting.hpp @@ -183,5 +183,16 @@ std::unique_ptr sort(table_view const& values, rmm::cuda_stream_view stream, rmm::mr::device_memory_resource* mr); +/** + * @copydoc cudf::stable_sort + * + * @param stream CUDA stream used for device memory operations and kernel launches. + */ +std::unique_ptr
stable_sort(table_view const& values, + std::vector const& column_order, + std::vector const& null_precedence, + rmm::cuda_stream_view stream, + rmm::mr::device_memory_resource* mr); + } // namespace detail } // namespace cudf diff --git a/cpp/include/cudf/sorting.hpp b/cpp/include/cudf/sorting.hpp index 5f8c6bf4ade..42bcb5da8e3 100644 --- a/cpp/include/cudf/sorting.hpp +++ b/cpp/include/cudf/sorting.hpp @@ -115,6 +115,18 @@ std::unique_ptr
sort( rmm::cuda_stream_view stream = cudf::get_default_stream(), rmm::mr::device_memory_resource* mr = rmm::mr::get_current_device_resource()); +/** + * @brief Performs a stable lexicographic sort of the rows of a table + * + * @copydoc cudf::sort + */ +std::unique_ptr
stable_sort( + table_view const& input, + std::vector const& column_order = {}, + std::vector const& null_precedence = {}, + rmm::cuda_stream_view stream = cudf::get_default_stream(), + rmm::mr::device_memory_resource* mr = rmm::mr::get_current_device_resource()); + /** * @brief Performs a key-value sort. * diff --git a/cpp/src/sort/stable_sort.cu b/cpp/src/sort/stable_sort.cu index cf602dcf1a9..2d17ca3eeb5 100644 --- a/cpp/src/sort/stable_sort.cu +++ b/cpp/src/sort/stable_sort.cu @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019-2023, NVIDIA CORPORATION. + * Copyright (c) 2019-2024, NVIDIA CORPORATION. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -37,6 +37,28 @@ std::unique_ptr stable_sorted_order(table_view const& input, return sorted_order(input, column_order, null_precedence, stream, mr); } +std::unique_ptr
stable_sort(table_view const& input, + std::vector const& column_order, + std::vector const& null_precedence, + rmm::cuda_stream_view stream, + rmm::mr::device_memory_resource* mr) +{ + // fast-path sort conditions: single, non-floating-point, fixed-width column with no nulls + if (input.num_columns() == 1 && !input.column(0).has_nulls() && + cudf::is_fixed_width(input.column(0).type()) && + !cudf::is_floating_point(input.column(0).type())) { + auto output = std::make_unique(input.column(0), stream, mr); + auto view = output->mutable_view(); + bool ascending = (column_order.empty() ? true : column_order.front() == order::ASCENDING); + cudf::type_dispatcher( + output->type(), inplace_column_sort_fn{}, view, ascending, stream); + std::vector> columns; + columns.emplace_back(std::move(output)); + return std::make_unique
(std::move(columns)); + } + return detail::stable_sort_by_key(input, input, column_order, null_precedence, stream, mr); +} + std::unique_ptr
stable_sort_by_key(table_view const& values, table_view const& keys, std::vector const& column_order, @@ -69,6 +91,16 @@ std::unique_ptr stable_sorted_order(table_view const& input, return detail::stable_sorted_order(input, column_order, null_precedence, stream, mr); } +std::unique_ptr
stable_sort(table_view const& input, + std::vector const& column_order, + std::vector const& null_precedence, + rmm::cuda_stream_view stream, + rmm::mr::device_memory_resource* mr) +{ + CUDF_FUNC_RANGE(); + return detail::stable_sort(input, column_order, null_precedence, stream, mr); +} + std::unique_ptr
stable_sort_by_key(table_view const& values, table_view const& keys, std::vector const& column_order,