From a921dca2556cb28178df186b70333ab11cce439f Mon Sep 17 00:00:00 2001 From: Hartmut Kaiser Date: Thu, 2 May 2024 19:20:17 -0500 Subject: [PATCH] Remove equal_to from hpx::any --- .../include/hpx/datastructures/any.hpp | 70 ----------- .../include/hpx/serialization/access.hpp | 20 ++-- .../tests/regressions/CMakeLists.txt | 3 +- .../trivially_copyable_all_gather.cpp | 109 ++++++++++++++++++ 4 files changed, 121 insertions(+), 81 deletions(-) create mode 100644 libs/full/collectives/tests/regressions/trivially_copyable_all_gather.cpp diff --git a/libs/core/datastructures/include/hpx/datastructures/any.hpp b/libs/core/datastructures/include/hpx/datastructures/any.hpp index 8063996ad79d..9f3b432d5291 100644 --- a/libs/core/datastructures/include/hpx/datastructures/any.hpp +++ b/libs/core/datastructures/include/hpx/datastructures/any.hpp @@ -107,7 +107,6 @@ namespace hpx::util::detail::any { void (*destruct)(void**) = nullptr; void (*clone)(void* const*, void**) = nullptr; void (*copy)(void* const*, void**) = nullptr; - bool (*equal_to)(void* const*, void* const*) = nullptr; }; template <> @@ -127,7 +126,6 @@ namespace hpx::util::detail::any { std::type_info const& (*get_type)() = nullptr; void (*static_delete)(void**) = nullptr; void (*destruct)(void**) = nullptr; - bool (*equal_to)(void* const*, void* const*) = nullptr; }; //////////////////////////////////////////////////////////////////////// @@ -472,7 +470,6 @@ namespace hpx::util::detail::any { base_type::destruct = Vtable::destruct; base_type::clone = Vtable::clone; base_type::copy = Vtable::copy; - base_type::equal_to = Vtable::equal_to; } [[nodiscard]] base_type* get_ptr() override @@ -496,7 +493,6 @@ namespace hpx::util::detail::any { base_type::destruct = Vtable::destruct; base_type::clone = Vtable::clone; base_type::copy = Vtable::copy; - base_type::equal_to = Vtable::equal_to; base_type::stream_in = Vtable::stream_in; base_type::stream_out = Vtable::stream_out; } @@ -520,7 +516,6 @@ namespace hpx::util::detail::any { base_type::get_type = Vtable::get_type; base_type::static_delete = Vtable::static_delete; base_type::destruct = Vtable::destruct; - base_type::equal_to = Vtable::equal_to; } [[nodiscard]] base_type* get_ptr() override @@ -542,7 +537,6 @@ namespace hpx::util::detail::any { base_type::get_type = Vtable::get_type; base_type::static_delete = Vtable::static_delete; base_type::destruct = Vtable::destruct; - base_type::equal_to = Vtable::equal_to; base_type::stream_in = Vtable::stream_in; base_type::stream_out = Vtable::stream_out; } @@ -830,22 +824,6 @@ namespace hpx::util { } } - // equality operator - [[nodiscard]] bool equal_to(basic_any const& rhs) const noexcept - { - if (this == &rhs) // same object - { - return true; - } - - if (type() == rhs.type()) // same type - { - return table->equal_to(&object, &rhs.object); // equal value? - } - - return false; - } - private: // types friend struct detail::any::any_cast_support; @@ -1043,22 +1021,6 @@ namespace hpx::util { } } - // equality operator - bool equal_to(basic_any const& rhs) const noexcept - { - if (this == &rhs) // same object - { - return true; - } - - if (type() == rhs.type()) // same type - { - return table->equal_to(&object, &rhs.object); // equal value? - } - - return false; - } - private: // types friend struct detail::any::any_cast_support; friend struct detail::any::stream_support; @@ -1224,22 +1186,6 @@ namespace hpx::util { } } - // equality operator - bool equal_to(basic_any const& rhs) const noexcept - { - if (this == &rhs) // same object - { - return true; - } - - if (type() == rhs.type()) // same type - { - return table->equal_to(&object, &rhs.object); // equal value? - } - - return false; - } - private: // types friend struct detail::any::any_cast_support; @@ -1402,22 +1348,6 @@ namespace hpx::util { } } - // equality operator - bool equal_to(basic_any const& rhs) const noexcept - { - if (this == &rhs) // same object - { - return true; - } - - if (type() == rhs.type()) // same type - { - return table->equal_to(&object, &rhs.object); // equal value? - } - - return false; - } - private: // types friend struct detail::any::any_cast_support; friend struct detail::any::stream_support; diff --git a/libs/core/serialization/include/hpx/serialization/access.hpp b/libs/core/serialization/include/hpx/serialization/access.hpp index 6d93f92d2217..2414fe239c8c 100644 --- a/libs/core/serialization/include/hpx/serialization/access.hpp +++ b/libs/core/serialization/include/hpx/serialization/access.hpp @@ -94,7 +94,14 @@ namespace hpx::serialization { else if constexpr (!std::is_empty_v
) { // non_intrusive - if constexpr (hpx::traits::has_serialize_adl_v
) + if constexpr (hpx::traits::is_bitwise_serializable_v
|| + !hpx::traits::is_not_bitwise_serializable_v
) + { + // bitwise serializable types can be directly dispatched to + // the archive functions + ar.invoke(t); + } + else if constexpr (hpx::traits::has_serialize_adl_v
) { // this additional indirection level is needed to force ADL // on the second phase of template lookup. call of serialize @@ -105,17 +112,10 @@ namespace hpx::serialization { else if constexpr (hpx::traits::has_struct_serialization_v
) { // This is automatic serialization for types that are simple - // (brace-initializable) structs, what that means every - // struct's field has to be serializable and public. + // (brace-initializable) structs, that means every struct's + // field has to be serializable and public. serialize_struct(ar, t, 0); } - else if constexpr (hpx::traits::is_bitwise_serializable_v
|| - !hpx::traits::is_not_bitwise_serializable_v
) - { - // bitwise serializable types can be directly dispatched to - // the archive functions - ar.invoke(t); - } else { static_assert(hpx::traits::has_serialize_adl_v
|| diff --git a/libs/full/collectives/tests/regressions/CMakeLists.txt b/libs/full/collectives/tests/regressions/CMakeLists.txt index 7b979a3de386..fcefda9314b4 100644 --- a/libs/full/collectives/tests/regressions/CMakeLists.txt +++ b/libs/full/collectives/tests/regressions/CMakeLists.txt @@ -1,4 +1,4 @@ -# Copyright (c) 2019-2022 The STE||AR-Group +# Copyright (c) 2019-2024 The STE||AR-Group # # SPDX-License-Identifier: BSL-1.0 # Distributed under the Boost Software License, Version 1.0. (See accompanying @@ -8,6 +8,7 @@ if(HPX_WITH_NETWORKING) set(tests barrier_3792 barrier_hang broadcast_unwrap_future_2885 broadcast_wait_for_2822 collectives_bool_5940 multiple_gather_ops_2001 + trivially_copyable_all_gather ) set(broadcast_unwrap_future_2885_PARAMETERS LOCALITIES 2 THREADS_PER_LOCALITY diff --git a/libs/full/collectives/tests/regressions/trivially_copyable_all_gather.cpp b/libs/full/collectives/tests/regressions/trivially_copyable_all_gather.cpp new file mode 100644 index 000000000000..5a4e855ace17 --- /dev/null +++ b/libs/full/collectives/tests/regressions/trivially_copyable_all_gather.cpp @@ -0,0 +1,109 @@ +// Copyright (c) 2024 Hartmut Kaiser +// +// SPDX-License-Identifier: BSL-1.0 +// Distributed under the Boost Software License, Version 1.0. (See accompanying +// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) + +#include + +#if !defined(HPX_COMPUTE_DEVICE_CODE) +#include +#include +#include +#include + +#include +#include +#include +#include + +using Dimension = unsigned short; + +template +class dimensioned_array +{ +public: + dimensioned_array() = default; + + explicit constexpr dimensioned_array(TYPE const& val) + : data_() + { + for (auto& x : data_) + x = val; + } + + constexpr bool operator==(dimensioned_array const& da) + { + return this->data_ == da.data_; + } + +private: + std::array data_; +}; + +template +using point = dimensioned_array; + +template +struct hpx::traits::is_bitwise_serializable> : std::true_type +{ +}; + +template +struct BBox +{ + point lower, upper; +}; + +void test_local_use() +{ + using namespace hpx::collectives; + + constexpr char const* all_gather_direct_basename = + "/test/all_gather_direct/"; + constexpr int ITERATIONS = 100; + constexpr std::uint32_t num_sites = 10; + + std::vector> sites; + sites.reserve(num_sites); + + // launch num_sites threads to represent different sites + for (std::uint32_t site = 0; site != num_sites; ++site) + { + sites.push_back(hpx::async([=]() { + auto const all_gather_direct_client = + create_local_communicator(all_gather_direct_basename, + num_sites_arg(num_sites), this_site_arg(site)); + + for (std::uint32_t i = 0; i != 10 * ITERATIONS; ++i) + { + double const coord_x = i; + double const coord_y = i + 1; + hpx::future>> overall_result = + all_gather(all_gather_direct_client, + BBox<2>{point{coord_x}, + point{coord_y}}, + this_site_arg(site), generation_arg(i + 1)); + + std::vector> r = overall_result.get(); + HPX_TEST_EQ(r.size(), num_sites); + } + })); + } + + hpx::wait_all(std::move(sites)); +} + +int hpx_main() +{ + test_local_use(); + return hpx::finalize(); +} + +int main(int argc, char* argv[]) +{ + HPX_TEST_EQ(hpx::init(argc, argv), 0); + return hpx::util::report_errors(); +} + +#endif