test_sort_by_key.cpp 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  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 TestSortByKey
  11. #include <boost/test/unit_test.hpp>
  12. #include <boost/compute/system.hpp>
  13. #include <boost/compute/algorithm/sort_by_key.hpp>
  14. #include <boost/compute/algorithm/is_sorted.hpp>
  15. #include <boost/compute/container/vector.hpp>
  16. #include <boost/compute/types/struct.hpp>
  17. struct custom_struct
  18. {
  19. boost::compute::int_ x;
  20. boost::compute::int_ y;
  21. boost::compute::float2_ zw;
  22. };
  23. BOOST_COMPUTE_ADAPT_STRUCT(custom_struct, custom_struct, (x, y, zw))
  24. #include "check_macros.hpp"
  25. #include "context_setup.hpp"
  26. namespace compute = boost::compute;
  27. // test trivial sorting of zero element vectors
  28. BOOST_AUTO_TEST_CASE(sort_int_0)
  29. {
  30. compute::vector<int> keys(context);
  31. compute::vector<int> values(context);
  32. BOOST_CHECK_EQUAL(keys.size(), size_t(0));
  33. BOOST_CHECK_EQUAL(values.size(), size_t(0));
  34. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end()) == true);
  35. BOOST_CHECK(compute::is_sorted(values.begin(), values.end()) == true);
  36. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  37. }
  38. // test trivial sorting of one element vectors
  39. BOOST_AUTO_TEST_CASE(sort_int_1)
  40. {
  41. int keys_data[] = { 11 };
  42. int values_data[] = { 100 };
  43. compute::vector<int> keys(keys_data, keys_data + 1, queue);
  44. compute::vector<int> values(values_data, values_data + 1, queue);
  45. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == true);
  46. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == true);
  47. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  48. }
  49. // test trivial sorting of two element vectors
  50. BOOST_AUTO_TEST_CASE(sort_int_2)
  51. {
  52. int keys_data[] = { 4, 2 };
  53. int values_data[] = { 42, 24 };
  54. compute::vector<int> keys(keys_data, keys_data + 2, queue);
  55. compute::vector<int> values(values_data, values_data + 2, queue);
  56. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == false);
  57. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == false);
  58. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  59. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == true);
  60. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == true);
  61. }
  62. BOOST_AUTO_TEST_CASE(sort_char_by_int)
  63. {
  64. int keys_data[] = { 6, 2, 1, 3, 4, 7, 5, 0 };
  65. compute::char_ values_data[] = { 'g', 'c', 'b', 'd', 'e', 'h', 'f', 'a' };
  66. compute::vector<int> keys(keys_data, keys_data + 8, queue);
  67. compute::vector<compute::char_> values(values_data, values_data + 8, queue);
  68. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  69. CHECK_RANGE_EQUAL(int, 8, keys, (0, 1, 2, 3, 4, 5, 6, 7));
  70. CHECK_RANGE_EQUAL(compute::char_, 8, values, ('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'));
  71. }
  72. BOOST_AUTO_TEST_CASE(sort_int_and_float)
  73. {
  74. int n = 1024;
  75. std::vector<int> host_keys(n);
  76. std::vector<float> host_values(n);
  77. for(int i = 0; i < n; i++){
  78. host_keys[i] = n - i;
  79. host_values[i] = (n - i) / 2.f;
  80. }
  81. compute::vector<int> keys(host_keys.begin(), host_keys.end(), queue);
  82. compute::vector<float> values(host_values.begin(), host_values.end(), queue);
  83. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == false);
  84. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == false);
  85. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  86. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == true);
  87. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == true);
  88. }
  89. BOOST_AUTO_TEST_CASE(sort_int_and_float_custom_comparison_func)
  90. {
  91. using boost::compute::int_;
  92. using boost::compute::float_;
  93. int n = 1024;
  94. std::vector<int_> host_keys(n);
  95. std::vector<float_> host_values(n);
  96. for(int i = 0; i < n; i++){
  97. host_keys[i] = n - i;
  98. host_values[i] = (n - i) / 2.f;
  99. }
  100. BOOST_COMPUTE_FUNCTION(bool, sort_int, (int_ a, int_ b),
  101. {
  102. return a < b;
  103. });
  104. compute::vector<int_> keys(host_keys.begin(), host_keys.end(), queue);
  105. compute::vector<float_> values(host_values.begin(), host_values.end(), queue);
  106. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), sort_int, queue) == false);
  107. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == false);
  108. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), sort_int, queue);
  109. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), sort_int, queue) == true);
  110. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), queue) == true);
  111. }
  112. BOOST_AUTO_TEST_CASE(sort_int_and_float2)
  113. {
  114. using boost::compute::int_;
  115. using boost::compute::float2_;
  116. int n = 1024;
  117. std::vector<int_> host_keys(n);
  118. std::vector<float2_> host_values(n);
  119. for(int i = 0; i < n; i++){
  120. host_keys[i] = n - i;
  121. host_values[i] = float2_((n - i) / 2.f);
  122. }
  123. BOOST_COMPUTE_FUNCTION(bool, sort_float2, (float2_ a, float2_ b),
  124. {
  125. return a.x < b.x;
  126. });
  127. compute::vector<int_> keys(host_keys.begin(), host_keys.end(), queue);
  128. compute::vector<float2_> values(host_values.begin(), host_values.end(), queue);
  129. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == false);
  130. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), sort_float2, queue) == false);
  131. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  132. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == true);
  133. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), sort_float2, queue) == true);
  134. }
  135. BOOST_AUTO_TEST_CASE(sort_custom_struct_by_int)
  136. {
  137. using boost::compute::int_;
  138. using boost::compute::float2_;
  139. int_ n = 1024;
  140. std::vector<int_> host_keys(n);
  141. std::vector<custom_struct> host_values(n);
  142. for(int_ i = 0; i < n; i++){
  143. host_keys[i] = n - i;
  144. host_values[i].x = n - i;
  145. host_values[i].y = n - i;
  146. host_values[i].zw = float2_((n - i) / 0.5f);
  147. }
  148. BOOST_COMPUTE_FUNCTION(bool, sort_custom_struct, (custom_struct a, custom_struct b),
  149. {
  150. return a.x < b.x;
  151. });
  152. compute::vector<int_> keys(host_keys.begin(), host_keys.end(), queue);
  153. compute::vector<custom_struct> values(host_values.begin(), host_values.end(), queue);
  154. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == false);
  155. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), sort_custom_struct, queue) == false);
  156. compute::sort_by_key(keys.begin(), keys.end(), values.begin(), queue);
  157. BOOST_CHECK(compute::is_sorted(keys.begin(), keys.end(), queue) == true);
  158. BOOST_CHECK(compute::is_sorted(values.begin(), values.end(), sort_custom_struct, queue) == true);
  159. }
  160. BOOST_AUTO_TEST_SUITE_END()