test_uniform_int_distribution.cpp 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. //---------------------------------------------------------------------------//
  2. // Copyright (c) 2014 Roshan <thisisroshansmail@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 TestUniformIntDistribution
  11. #include <boost/test/unit_test.hpp>
  12. #include <boost/compute/system.hpp>
  13. #include <boost/compute/command_queue.hpp>
  14. #include <boost/compute/algorithm/count_if.hpp>
  15. #include <boost/compute/container/vector.hpp>
  16. #include <boost/compute/random/default_random_engine.hpp>
  17. #include <boost/compute/random/uniform_int_distribution.hpp>
  18. #include <boost/compute/lambda.hpp>
  19. #include "context_setup.hpp"
  20. namespace compute=boost::compute;
  21. BOOST_AUTO_TEST_CASE(uniform_int_distribution_doctest)
  22. {
  23. using boost::compute::uint_;
  24. using boost::compute::lambda::_1;
  25. boost::compute::vector<uint_> vec(128, context);
  26. //! [generate]
  27. // initialize the default random engine
  28. boost::compute::default_random_engine engine(queue);
  29. // setup the uniform distribution to produce integers 0 and 1
  30. boost::compute::uniform_int_distribution<uint_> distribution(0, 1);
  31. // generate the random values and store them to 'vec'
  32. distribution.generate(vec.begin(), vec.end(), engine, queue);
  33. //! [generate]
  34. BOOST_CHECK_EQUAL(
  35. boost::compute::count_if(
  36. vec.begin(), vec.end(), _1 > 1, queue
  37. ),
  38. size_t(0)
  39. );
  40. }
  41. BOOST_AUTO_TEST_CASE(issue159) {
  42. using boost::compute::lambda::_1;
  43. boost::compute::vector<int> input(10, context);
  44. // generate random numbers between 1 and 10
  45. compute::default_random_engine rng(queue);
  46. compute::uniform_int_distribution<int> d(1, 10);
  47. d.generate(input.begin(), input.end(), rng, queue);
  48. BOOST_CHECK_EQUAL(
  49. boost::compute::count_if(
  50. input.begin(), input.end(), _1 > 10, queue
  51. ),
  52. size_t(0)
  53. );
  54. BOOST_CHECK_EQUAL(
  55. boost::compute::count_if(
  56. input.begin(), input.end(), _1 < 1, queue
  57. ),
  58. size_t(0)
  59. );
  60. }
  61. BOOST_AUTO_TEST_SUITE_END()