test_parallel_stable_sort.cpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. //----------------------------------------------------------------------------
  2. /// @file test_parallel_stable_sort.cpp
  3. /// @brief test program of the parallel_stable_sort algorithm
  4. ///
  5. /// @author Copyright (c) 2016 Francisco Jose Tapia (fjtapia@gmail.com )\n
  6. /// Distributed under the Boost Software License, Version 1.0.\n
  7. /// ( See accompanying file LICENSE_1_0.txt or copy at
  8. /// http://www.boost.org/LICENSE_1_0.txt )
  9. /// @version 0.1
  10. ///
  11. /// @remarks
  12. //-----------------------------------------------------------------------------
  13. #include <ciso646>
  14. #include <cstdio>
  15. #include <cstdlib>
  16. #include <ctime>
  17. #include <vector>
  18. #include <random>
  19. #include <algorithm>
  20. #include <boost/sort/parallel_stable_sort/parallel_stable_sort.hpp>
  21. #include <boost/test/included/test_exec_monitor.hpp>
  22. #include <boost/test/test_tools.hpp>
  23. namespace bss = boost::sort;
  24. struct xk
  25. {
  26. unsigned tail : 4;
  27. unsigned num : 28;
  28. xk ( uint32_t n =0 , uint32_t t =0): tail (t), num(n){};
  29. bool operator< (xk A) const { return (num < A.num); };
  30. };
  31. void test1()
  32. {
  33. std::mt19937_64 my_rand(0);
  34. const uint32_t NMAX = 100000;
  35. std::vector<xk> V1, V2, V3;
  36. V1.reserve(NMAX);
  37. for (uint32_t i = 0; i < 8; ++i)
  38. {
  39. for (uint32_t k = 0; k < NMAX; ++k)
  40. { uint32_t NM = my_rand();
  41. xk G;
  42. G.num = NM >> 3;
  43. G.tail = i;
  44. V1.push_back(G);
  45. };
  46. };
  47. V3 = V2 = V1;
  48. bss::parallel_stable_sort(V1.begin(), V1.end());
  49. std::stable_sort(V2.begin(), V2.end());
  50. bss::parallel_stable_sort(V3.begin(), V3.end(), 0);
  51. BOOST_CHECK(V1.size() == V2.size());
  52. for (uint32_t i = 0; i < V1.size(); ++i)
  53. { BOOST_CHECK(V1[i].num == V2[i].num and V1[i].tail == V2[i].tail);
  54. };
  55. BOOST_CHECK(V3.size() == V2.size());
  56. for (uint32_t i = 0; i < V3.size(); ++i)
  57. { BOOST_CHECK(V3[i].num == V2[i].num and V3[i].tail == V2[i].tail);
  58. };
  59. };
  60. void test2(void)
  61. {
  62. const uint32_t NElem = 2000000;
  63. std::vector<uint64_t> V1;
  64. // ----------------- sorted elements ------------------------------------
  65. V1.clear();
  66. for (uint32_t i = 0; i < NElem; ++i) V1.push_back(i);
  67. bss::parallel_stable_sort(V1.begin(), V1.end());
  68. for (unsigned i = 1; i < NElem; i++)
  69. { BOOST_CHECK(V1[i - 1] <= V1[i]);
  70. };
  71. // ------------- reverse sorted elements --------------------------------
  72. V1.clear();
  73. for (uint32_t i = 0; i < NElem; ++i) V1.push_back(NElem - i);
  74. bss::parallel_stable_sort(V1.begin(), V1.end());
  75. for (unsigned i = 1; i < NElem; i++)
  76. { BOOST_CHECK(V1[i - 1] <= V1[i]);
  77. };
  78. // -------------------- equals elements -----------------------------------
  79. V1.clear();
  80. for (uint32_t i = 0; i < NElem; ++i) V1.push_back(1000);
  81. bss::parallel_stable_sort(V1.begin(), V1.end());
  82. for (unsigned i = 1; i < NElem; i++)
  83. { BOOST_CHECK(V1[i - 1] == V1[i]);
  84. };
  85. };
  86. void test3(void)
  87. {
  88. const uint32_t NElem = 2000000;
  89. std::vector<uint64_t> V1,V2,V3;
  90. std::mt19937_64 my_rand(0);
  91. for (uint32_t i = 0; i < NElem; ++i) V1.push_back(my_rand() % NElem);
  92. V3 = V2 = V1;
  93. std::stable_sort (V2.begin(), V2.end());
  94. // --------------- unsorted elements 0 threads ----------------------------
  95. V3 = V1;
  96. bss::parallel_stable_sort(V3.begin(), V3.end(), 0);
  97. for (unsigned i = 0; i < NElem; i++)
  98. { BOOST_CHECK(V3[i] == V2[i]);
  99. };
  100. // --------------- unsorted elements -------------------------------------
  101. V3 = V1;
  102. bss::parallel_stable_sort(V3.begin(), V3.end());
  103. for (unsigned i = 0; i < NElem; i++)
  104. { BOOST_CHECK(V3[i] == V2[i]);
  105. };
  106. // --------------- unsorted elements 100 threads ----------------------------
  107. V3 = V1;
  108. bss::parallel_stable_sort(V3.begin(), V3.end(), 100);
  109. for (unsigned i = 0; i < NElem; i++)
  110. { BOOST_CHECK(V3[i] == V2[i]);
  111. };
  112. };
  113. void test4(void)
  114. {
  115. typedef std::less<uint64_t> compare;
  116. const uint32_t KMax = 66000;
  117. std::vector<uint64_t> K, M;
  118. std::mt19937_64 my_rand(0);
  119. for (uint32_t i = 0; i < KMax; ++i)
  120. K.push_back(my_rand());
  121. M = K;
  122. bss::parallel_stable_sort(K.begin(), K.end(), compare(), 300);
  123. std::stable_sort(M.begin(), M.end(), compare());
  124. for (unsigned i = 0; i < KMax; i++)
  125. BOOST_CHECK(M[i] == K[i]);
  126. };
  127. void test5 (void)
  128. {
  129. typedef typename std::vector<xk>::iterator iter_t;
  130. std::mt19937 my_rand (0);
  131. std::vector<xk> V ;
  132. const uint32_t NELEM = 100000;
  133. V.reserve(NELEM * 10);
  134. for (uint32_t k =0 ; k < 10 ; ++k)
  135. { for ( uint32_t i =0 ; i < NELEM ; ++i)
  136. { V.emplace_back(i , k);
  137. };
  138. iter_t first = V.begin() + (k * NELEM);
  139. iter_t last = first + NELEM ;
  140. std::shuffle( first, last, my_rand);
  141. };
  142. bss::parallel_stable_sort( V.begin() , V.end());
  143. for ( uint32_t i =0 ; i < ( NELEM * 10); ++i)
  144. { BOOST_CHECK ( V[i].num == (i / 10) and V[i].tail == (i %10) );
  145. };
  146. }
  147. int test_main(int, char *[])
  148. {
  149. test1();
  150. test2();
  151. test3();
  152. test4();
  153. test5();
  154. return 0;
  155. };