parallel_sort.cpp 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // Copyright 2009-2020 Intel Corporation
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include "parallel_sort.h"
  4. #include "../sys/regression.h"
  5. namespace embree
  6. {
  7. template<typename Key>
  8. struct RadixSortRegressionTest : public RegressionTest
  9. {
  10. RadixSortRegressionTest(const char* name) : RegressionTest(name) {
  11. registerRegressionTest(this);
  12. }
  13. bool run ()
  14. {
  15. bool passed = true;
  16. const size_t M = 10;
  17. for (size_t N=10; N<1000000; N=size_t(2.1*N))
  18. {
  19. std::vector<Key> src(N); memset(src.data(),0,N*sizeof(Key));
  20. std::vector<Key> tmp(N); memset(tmp.data(),0,N*sizeof(Key));
  21. for (size_t i=0; i<N; i++) src[i] = uint64_t(rand())*uint64_t(rand());
  22. /* calculate checksum */
  23. Key sum0 = 0; for (size_t i=0; i<N; i++) sum0 += src[i];
  24. /* sort numbers */
  25. for (size_t i=0; i<M; i++) {
  26. radix_sort<Key>(src.data(),tmp.data(),N);
  27. }
  28. /* calculate checksum */
  29. Key sum1 = 0; for (size_t i=0; i<N; i++) sum1 += src[i];
  30. if (sum0 != sum1) passed = false;
  31. /* check if numbers are sorted */
  32. for (size_t i=1; i<N; i++)
  33. passed &= src[i-1] <= src[i];
  34. }
  35. return passed;
  36. }
  37. };
  38. RadixSortRegressionTest<uint32_t> test_u32("RadixSortRegressionTestU32");
  39. RadixSortRegressionTest<uint64_t> test_u64("RadixSortRegressionTestU64");
  40. }