151c0b2f7Stbbdev /*
2*b15aabb3Stbbdev     Copyright (c) 2020-2021 Intel Corporation
351c0b2f7Stbbdev 
451c0b2f7Stbbdev     Licensed under the Apache License, Version 2.0 (the "License");
551c0b2f7Stbbdev     you may not use this file except in compliance with the License.
651c0b2f7Stbbdev     You may obtain a copy of the License at
751c0b2f7Stbbdev 
851c0b2f7Stbbdev         http://www.apache.org/licenses/LICENSE-2.0
951c0b2f7Stbbdev 
1051c0b2f7Stbbdev     Unless required by applicable law or agreed to in writing, software
1151c0b2f7Stbbdev     distributed under the License is distributed on an "AS IS" BASIS,
1251c0b2f7Stbbdev     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1351c0b2f7Stbbdev     See the License for the specific language governing permissions and
1451c0b2f7Stbbdev     limitations under the License.
1551c0b2f7Stbbdev */
1651c0b2f7Stbbdev 
1751c0b2f7Stbbdev #include "common/test.h"
1851c0b2f7Stbbdev #include "common/utils_concurrency_limit.h"
1951c0b2f7Stbbdev 
2049e08aacStbbdev #include "oneapi/tbb/parallel_sort.h"
2149e08aacStbbdev #include "oneapi/tbb/global_control.h"
2251c0b2f7Stbbdev 
2351c0b2f7Stbbdev #include <vector>
2451c0b2f7Stbbdev 
2551c0b2f7Stbbdev //! \file conformance_parallel_sort.cpp
2651c0b2f7Stbbdev //! \brief Test for [algorithms.parallel_sort]
2751c0b2f7Stbbdev 
2851c0b2f7Stbbdev const int vector_size = 10000;
2951c0b2f7Stbbdev 
get_random_vector()3051c0b2f7Stbbdev std::vector<int> get_random_vector() {
3151c0b2f7Stbbdev     std::vector<int> result(vector_size);
3251c0b2f7Stbbdev     for (int i = 0; i < vector_size; ++i)
3351c0b2f7Stbbdev         result[i] = rand() % vector_size;
3451c0b2f7Stbbdev     return result;
3551c0b2f7Stbbdev }
3651c0b2f7Stbbdev 
3751c0b2f7Stbbdev //! Iterator based range sorting test (default comparator)
3851c0b2f7Stbbdev //! \brief \ref requirement \ref interface
3951c0b2f7Stbbdev TEST_CASE("Iterator based range sorting test (default comparator)") {
4051c0b2f7Stbbdev     for ( auto concurrency_level : utils::concurrency_range() ) {
4149e08aacStbbdev         oneapi::tbb::global_control control(oneapi::tbb::global_control::max_allowed_parallelism, concurrency_level);
4251c0b2f7Stbbdev 
4351c0b2f7Stbbdev         auto test_vector = get_random_vector();
4449e08aacStbbdev         oneapi::tbb::parallel_sort(test_vector.begin(), test_vector.end());
4551c0b2f7Stbbdev 
4651c0b2f7Stbbdev         for(auto it = test_vector.begin(); it != test_vector.end() - 1; ++it)
4751c0b2f7Stbbdev             REQUIRE_MESSAGE(*it <= *(it+1), "Testing data not sorted");
4851c0b2f7Stbbdev     }
4951c0b2f7Stbbdev }
5051c0b2f7Stbbdev 
5151c0b2f7Stbbdev //! Iterator based range sorting test (greater comparator)
5251c0b2f7Stbbdev //! \brief \ref requirement \ref interface
5351c0b2f7Stbbdev TEST_CASE ("Iterator based range sorting test (greater comparator)") {
5451c0b2f7Stbbdev     for ( auto concurrency_level : utils::concurrency_range() ) {
5549e08aacStbbdev         oneapi::tbb::global_control control(oneapi::tbb::global_control::max_allowed_parallelism, concurrency_level);
5651c0b2f7Stbbdev 
5751c0b2f7Stbbdev         auto test_vector = get_random_vector();
5849e08aacStbbdev         oneapi::tbb::parallel_sort(test_vector.begin(), test_vector.end(), std::greater<int>());
5951c0b2f7Stbbdev 
6051c0b2f7Stbbdev         for(auto it = test_vector.begin(); it != test_vector.end() - 1; ++it)
6151c0b2f7Stbbdev             REQUIRE_MESSAGE(*it >= *(it+1), "Testing data not sorted");
6251c0b2f7Stbbdev     }
6351c0b2f7Stbbdev }
6451c0b2f7Stbbdev 
6551c0b2f7Stbbdev //! Range sorting test (default comparator)
6651c0b2f7Stbbdev //! \brief \ref requirement \ref interface
6751c0b2f7Stbbdev TEST_CASE ("Range sorting test (default comparator)") {
6851c0b2f7Stbbdev     for ( auto concurrency_level : utils::concurrency_range() ) {
6949e08aacStbbdev         oneapi::tbb::global_control control(oneapi::tbb::global_control::max_allowed_parallelism, concurrency_level);
7051c0b2f7Stbbdev 
7151c0b2f7Stbbdev         auto test_vector = get_random_vector();
7249e08aacStbbdev         oneapi::tbb::parallel_sort(test_vector);
7351c0b2f7Stbbdev 
7451c0b2f7Stbbdev         for(auto it = test_vector.begin(); it != test_vector.end() - 1; ++it)
7551c0b2f7Stbbdev             REQUIRE_MESSAGE(*it <= *(it+1), "Testing data not sorted");
7651c0b2f7Stbbdev     }
7751c0b2f7Stbbdev }
7851c0b2f7Stbbdev 
7951c0b2f7Stbbdev //! Range sorting test (greater comparator)
8051c0b2f7Stbbdev //! \brief \ref requirement \ref interface
8151c0b2f7Stbbdev TEST_CASE ("Range sorting test (greater comparator)") {
8251c0b2f7Stbbdev     for ( auto concurrency_level : utils::concurrency_range() ) {
8349e08aacStbbdev         oneapi::tbb::global_control control(oneapi::tbb::global_control::max_allowed_parallelism, concurrency_level);
8451c0b2f7Stbbdev 
8551c0b2f7Stbbdev         auto test_vector = get_random_vector();
8649e08aacStbbdev         oneapi::tbb::parallel_sort(test_vector, std::greater<int>());
8751c0b2f7Stbbdev 
8851c0b2f7Stbbdev         for(auto it = test_vector.begin(); it != test_vector.end() - 1; ++it)
8951c0b2f7Stbbdev             REQUIRE_MESSAGE(*it >= *(it+1), "Testing data not sorted");
9051c0b2f7Stbbdev     }
9151c0b2f7Stbbdev }
92