From 808fdc14b788b8c287aee84fb3bce190b385519d Mon Sep 17 00:00:00 2001 From: Martin Marenz Date: Thu, 24 Aug 2023 16:05:00 +0200 Subject: [PATCH] Add `bytes_per_second` to copy_if_else benchmark Adds `bytes_per_second to `COPY_IF_ELSE_BENCH`. This patch relates to #13735. --- cpp/benchmarks/copying/copy_if_else.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/cpp/benchmarks/copying/copy_if_else.cpp b/cpp/benchmarks/copying/copy_if_else.cpp index a10f54b3d6f..50ddfb82feb 100644 --- a/cpp/benchmarks/copying/copy_if_else.cpp +++ b/cpp/benchmarks/copying/copy_if_else.cpp @@ -47,6 +47,14 @@ static void BM_copy_if_else(benchmark::State& state, bool nulls) cuda_event_timer raii(state, true, cudf::get_default_stream()); cudf::copy_if_else(lhs, rhs, decision); } + + auto const bytes_read = n_rows * (sizeof(TypeParam) + sizeof(bool)); + auto const bytes_written = n_rows * sizeof(TypeParam); + auto const null_bytes = nulls ? 2 * cudf::bitmask_allocation_size_bytes(n_rows) : 0; + + // Use number of bytes read and written. + state.SetBytesProcessed(static_cast(state.iterations()) * + (bytes_read + bytes_written + null_bytes)); } #define COPY_BENCHMARK_DEFINE(name, type, b) \