// -*- C++ -*- //===-- test_none_of.cpp --------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "pstl_test_config.h" #include "pstl/execution" #include "pstl/algorithm" #include "utils.h" /* TODO: consider implementing the following tests for a better code coverage - correctness - bad input argument (if applicable) - data corruption around/of input and output - correctly work with nested parallelism - check that algorithm does not require anything more than is described in its requirements section */ using namespace TestUtils; struct test_none_of { template void operator()(ExecutionPolicy&& exec, Iterator begin, Iterator end, Predicate pred, bool expected) { auto actualr = std::none_of(exec, begin, end, pred); EXPECT_EQ(expected, actualr, "result for none_of"); } }; template void test(size_t bits) { for (size_t n = 0; n <= 100000; n = n <= 16 ? n + 1 : size_t(3.1415 * n)) { // Sequence of odd values Sequence in(n, [n, bits](size_t k) { return T(2 * HashBits(n, bits - 1) ^ 1); }); // Even value, or false when T is bool. T spike(2 * HashBits(n, bits - 1)); invoke_on_all_policies(test_none_of(), in.begin(), in.end(), is_equal_to(spike), true); invoke_on_all_policies(test_none_of(), in.cbegin(), in.cend(), is_equal_to(spike), true); if (n > 0) { // Sprinkle in a hit in[2 * n / 3] = spike; invoke_on_all_policies(test_none_of(), in.begin(), in.end(), is_equal_to(spike), false); invoke_on_all_policies(test_none_of(), in.cbegin(), in.cend(), is_equal_to(spike), false); // Sprinkle in a few more hits in[n / 3] = spike; in[n / 2] = spike; invoke_on_all_policies(test_none_of(), in.begin(), in.end(), is_equal_to(spike), false); invoke_on_all_policies(test_none_of(), in.cbegin(), in.cend(), is_equal_to(spike), false); } } } struct test_non_const { template void operator()(Policy&& exec, Iterator iter) { auto is_even = [&](float64_t v) { uint32_t i = (uint32_t)v; return i % 2 == 0; }; none_of(exec, iter, iter, non_const(is_even)); } }; int32_t main() { test(8 * sizeof(int32_t)); test(8 * sizeof(uint16_t)); test(53); #if !__PSTL_ICC_16_17_TEST_REDUCTION_BOOL_TYPE_RELEASE_64_BROKEN test(1); #endif test_algo_basic_single(run_for_rnd_fw()); std::cout << done() << std::endl; return 0; }