test_random_shuffle.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. //---------------------------------------------------------------------------//
  2. // Copyright (c) 2013 Kyle Lutz <kyle.r.lutz@gmail.com>
  3. //
  4. // Distributed under the Boost Software License, Version 1.0
  5. // See accompanying file LICENSE_1_0.txt or copy at
  6. // http://www.boost.org/LICENSE_1_0.txt
  7. //
  8. // See http://boostorg.github.com/compute for more information.
  9. //---------------------------------------------------------------------------//
  10. #define BOOST_TEST_MODULE TestRandomShuffle
  11. #include <boost/test/unit_test.hpp>
  12. #include <set>
  13. #include <iterator>
  14. #include <boost/compute/system.hpp>
  15. #include <boost/compute/command_queue.hpp>
  16. #include <boost/compute/algorithm/random_shuffle.hpp>
  17. #include <boost/compute/container/vector.hpp>
  18. #include "context_setup.hpp"
  19. namespace bc = boost::compute;
  20. BOOST_AUTO_TEST_CASE(shuffle_int_vector)
  21. {
  22. bc::vector<int> vector(context);
  23. vector.push_back(1, queue);
  24. vector.push_back(9, queue);
  25. vector.push_back(19, queue);
  26. vector.push_back(29, queue);
  27. queue.finish();
  28. std::set<int> original_values;
  29. for(size_t i = 0; i < vector.size(); i++){
  30. original_values.insert(vector[i]);
  31. }
  32. BOOST_CHECK_EQUAL(original_values.size(), size_t(4));
  33. bc::random_shuffle(vector.begin(), vector.end(), queue);
  34. std::set<int> shuffled_values;
  35. bc::copy(
  36. vector.begin(),
  37. vector.end(),
  38. std::inserter(shuffled_values, shuffled_values.begin()),
  39. queue
  40. );
  41. BOOST_CHECK_EQUAL(shuffled_values.size(), size_t(4));
  42. BOOST_VERIFY(original_values == shuffled_values);
  43. }
  44. BOOST_AUTO_TEST_SUITE_END()