Skip to content

Commit

Permalink
Add a pure distributed callback test
Browse files Browse the repository at this point in the history
  • Loading branch information
aprokop committed Jun 25, 2024
1 parent 78f9d58 commit 07989b9
Showing 1 changed file with 61 additions and 0 deletions.
61 changes: 61 additions & 0 deletions test/tstDistributedTreeSpatial.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -275,6 +275,7 @@ struct CustomPostCallbackWithAttachment
});
}
};

BOOST_AUTO_TEST_CASE_TEMPLATE(callback_with_attachment, DeviceType,
ARBORX_DEVICE_TYPES)
{
Expand Down Expand Up @@ -376,6 +377,66 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(callback_with_attachment, DeviceType,
}
}

template <typename DeviceType>
struct CustomPureInlineCallback
{
Kokkos::View<int *, DeviceType> counts;

template <typename Query>
KOKKOS_FUNCTION void operator()(Query const &, int index) const
{
Kokkos::atomic_inc(&counts(index));
}
};

BOOST_AUTO_TEST_CASE_TEMPLATE(pure_spatial_callback, DeviceType,
ARBORX_DEVICE_TYPES)
{
using ExecutionSpace = typename DeviceType::execution_space;

MPI_Comm comm = MPI_COMM_WORLD;
int comm_rank;
MPI_Comm_rank(comm, &comm_rank);
int comm_size;
MPI_Comm_size(comm, &comm_size);

// +----------0----------1----------2----------3
// | | | | |
// | | | | |
// | | | | |
// | | | | |
// 0----------1----------2----------3----------+
// [ rank 0 ]
// [ rank 1 ]
// [ rank 2 ]
// [ rank 3 ]
auto const tree = makeDistributedTree<DeviceType>(
comm, {{{{(float)comm_rank, 0., 0.}}, {{(float)comm_rank + 1, 1., 1.}}}});

// +--------0---------1----------2---------3
// | | | | |
// | | | | |
// | | | | |
// | | | | |
// 0--------1----x----2-----x----3----x----+ x
// ^ ^ ^ ^
// 0 1 2 3
Kokkos::View<decltype(ArborX::intersects(ArborX::Point{})) *, DeviceType>
queries("Testing::queries", 1);
auto queries_host = Kokkos::create_mirror_view(queries);
queries_host(0) = ArborX::intersects(ArborX::Point{1.5f + comm_rank, 0, 0});
deep_copy(queries, queries_host);

Kokkos::View<int *, DeviceType> counts("Testing::counts", queries.size());
tree.query(ExecutionSpace{}, queries,
CustomPureInlineCallback<DeviceType>{counts});

std::vector<int> counts_ref;
counts_ref.push_back(comm_rank > 0);

BOOST_TEST(counts == counts_ref, tt::per_element());
}

BOOST_AUTO_TEST_CASE_TEMPLATE(boost_comparison, DeviceType, ARBORX_DEVICE_TYPES)
{
using ExecutionSpace = typename DeviceType::execution_space;
Expand Down

0 comments on commit 07989b9

Please sign in to comment.