From 85ff60b785c8033c32a243c904dd4383c71ef274 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20J=C3=BCnger?= Date: Tue, 1 Oct 2024 02:15:20 +0000 Subject: [PATCH] Clarify docs regarding heterogeneous lookup --- include/cuco/bloom_filter.cuh | 33 ++++++++----------------------- include/cuco/bloom_filter_ref.cuh | 18 +++++------------ 2 files changed, 13 insertions(+), 38 deletions(-) diff --git a/include/cuco/bloom_filter.cuh b/include/cuco/bloom_filter.cuh index 1373069d3..daef7253b 100644 --- a/include/cuco/bloom_filter.cuh +++ b/include/cuco/bloom_filter.cuh @@ -142,10 +142,7 @@ class bloom_filter { * @note This function synchronizes the given stream. For asynchronous execution use * `add_async`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` - * + * @tparam InputIt Device-accessible random access input key iterator * @param first Beginning of the sequence of keys * @param last End of the sequence of keys * @param stream CUDA stream this operation is executed in @@ -156,9 +153,7 @@ class bloom_filter { /** * @brief Asynchronously adds all keys in the range `[first, last)` to the filter. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * * @param first Beginning of the sequence of keys * @param last End of the sequence of keys @@ -175,9 +170,7 @@ class bloom_filter { * @note This function synchronizes the given stream and returns the number of successful * insertions. For asynchronous execution use `add_if_async`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam StencilIt Device-accessible random-access iterator whose `value_type` is * convertible to Predicate's argument type * @tparam Predicate Unary predicate callable whose return type must be convertible to `bool` and @@ -200,9 +193,7 @@ class bloom_filter { * * @note The key `*(first + i)` is added if `pred( *(stencil + i) )` returns `true`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam StencilIt Device-accessible random-access iterator whose `value_type` is * convertible to Predicate's argument type * @tparam Predicate Unary predicate callable whose return type must be convertible to `bool` and @@ -229,9 +220,7 @@ class bloom_filter { * @note This function synchronizes the given stream. For asynchronous execution use * `contains_async`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam OutputIt Device-accessible output iterator assignable from `bool` * * @param first Beginning of the sequence of keys @@ -249,9 +238,7 @@ class bloom_filter { * @brief Asynchronously tests all keys in the range `[first, last)` if their fingerprints are * present in the filter. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam OutputIt Device-accessible output iterator assignable from `bool` * * @param first Beginning of the sequence of keys @@ -273,9 +260,7 @@ class bloom_filter { * @note This function synchronizes the given stream. For asynchronous execution use * `contains_if_async`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam StencilIt Device-accessible random-access iterator whose `value_type` is * convertible to Predicate's argument type * @tparam Predicate Unary predicate callable whose return type must be convertible to `bool` and @@ -304,9 +289,7 @@ class bloom_filter { * * @note The key `*(first + i)` is queried if `pred( *(stencil + i) )` returns `true`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam StencilIt Device-accessible random-access iterator whose `value_type` is * convertible to Predicate's argument type * @tparam Predicate Unary predicate callable whose return type must be convertible to `bool` and diff --git a/include/cuco/bloom_filter_ref.cuh b/include/cuco/bloom_filter_ref.cuh index 00951cb44..7a6e095e0 100644 --- a/include/cuco/bloom_filter_ref.cuh +++ b/include/cuco/bloom_filter_ref.cuh @@ -110,7 +110,7 @@ class bloom_filter_ref { * @note Best performance is achieved if the size of the CG is equal to `words_per_block`. * * @tparam CG Cooperative Group type - * @tparam ProbeKey Input type that is implicitly convertible to `key_type` + * @tparam ProbeKey Input key type * * @param group The Cooperative Group this operation is executed with * @param key The key to be added @@ -124,9 +124,7 @@ class bloom_filter_ref { * @note This function synchronizes the given stream. For asynchronous execution use * `add_async`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * * @param first Beginning of the sequence of keys * @param last End of the sequence of keys @@ -138,9 +136,7 @@ class bloom_filter_ref { /** * @brief Asynchronously adds all keys in the range `[first, last)` to the filter. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * * @param first Beginning of the sequence of keys * @param last End of the sequence of keys @@ -157,9 +153,7 @@ class bloom_filter_ref { * @note This function synchronizes the given stream and returns the number of successful * insertions. For asynchronous execution use `add_if_async`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam StencilIt Device-accessible random-access iterator whose `value_type` is * convertible to Predicate's argument type * @tparam Predicate Unary predicate callable whose return type must be convertible to `bool` and @@ -182,9 +176,7 @@ class bloom_filter_ref { * * @note The key `*(first + i)` is added if `pred( *(stencil + i) )` returns `true`. * - * @tparam InputIt Device-accessible random access input iterator where - * std::is_convertible::value_type, - * bloom_filter::key_type> is `true` + * @tparam InputIt Device-accessible random access input key iterator * @tparam StencilIt Device-accessible random-access iterator whose `value_type` is * convertible to Predicate's argument type * @tparam Predicate Unary predicate callable whose return type must be convertible to `bool` and