1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
//@HEADER
// ************************************************************************
//
// Kokkos v. 4.0
// Copyright (2022) National Technology & Engineering
// Solutions of Sandia, LLC (NTESS).
//
// Under the terms of Contract DE-NA0003525 with NTESS,
// the U.S. Government retains certain rights in this software.
//
// Part of Kokkos, under the Apache License v2.0 with LLVM Exceptions.
// See https://kokkos.org/LICENSE for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//@HEADER
#include <TestAtomicOperations.hpp>
using namespace TestAtomicOperations;
namespace Test {
TEST(TEST_CATEGORY, atomic_operations_complexdouble) {
#if defined(KOKKOS_ENABLE_SYCL) && \
!defined(KOKKOS_IMPL_SYCL_DEVICE_GLOBAL_SUPPORTED)
if (std::is_same_v<TEST_EXECSPACE, Kokkos::SYCL>)
GTEST_SKIP() << "skipping since device_global variables are not available";
#endif
const int start = -5;
const int end = 11;
for (int i = start; i < end; ++i) {
using T = Kokkos::complex<double>;
T old_val = static_cast<T>(i);
T update = static_cast<T>(end - i - start);
ASSERT_TRUE(
(atomic_op_test<AddAtomicTest, T, TEST_EXECSPACE>(old_val, update)));
ASSERT_TRUE(
(atomic_op_test<SubAtomicTest, T, TEST_EXECSPACE>(old_val, update)));
ASSERT_TRUE(
(atomic_op_test<MulAtomicTest, T, TEST_EXECSPACE>(old_val, update)));
// FIXME_32BIT disable division test for 32bit where we have accuracy issues
// with division atomics still compile it though
if (sizeof(void*) == 8) {
ASSERT_TRUE((update != 0
? atomic_op_test<DivAtomicTest, T, TEST_EXECSPACE>(
old_val, update)
: true));
}
ASSERT_TRUE((atomic_op_test<LoadStoreAtomicTest, T, TEST_EXECSPACE>(
old_val, update)));
}
}
} // namespace Test
|