test_complex.cpp 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  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 TestComplex
  11. #include <boost/test/unit_test.hpp>
  12. #include <boost/compute/algorithm/copy.hpp>
  13. #include <boost/compute/algorithm/fill.hpp>
  14. #include <boost/compute/algorithm/transform.hpp>
  15. #include <boost/compute/container/vector.hpp>
  16. #include <boost/compute/types/complex.hpp>
  17. #include <boost/compute/type_traits/type_name.hpp>
  18. #include "context_setup.hpp"
  19. // copies a vector of complex<float>'s on the host to the device
  20. BOOST_AUTO_TEST_CASE(copy_complex_vector)
  21. {
  22. std::vector<std::complex<float> > host_vector;
  23. host_vector.push_back(std::complex<float>(1.0f, 2.0f));
  24. host_vector.push_back(std::complex<float>(-2.0f, 1.0f));
  25. host_vector.push_back(std::complex<float>(1.0f, -2.0f));
  26. host_vector.push_back(std::complex<float>(-2.0f, -1.0f));
  27. boost::compute::vector<std::complex<float> > device_vector(context);
  28. boost::compute::copy(
  29. host_vector.begin(),
  30. host_vector.end(),
  31. device_vector.begin(),
  32. queue
  33. );
  34. queue.finish();
  35. BOOST_CHECK_EQUAL(std::complex<float>(device_vector[0]), std::complex<float>(1.0f, 2.0f));
  36. BOOST_CHECK_EQUAL(std::complex<float>(device_vector[1]), std::complex<float>(-2.0f, 1.0f));
  37. BOOST_CHECK_EQUAL(std::complex<float>(device_vector[2]), std::complex<float>(1.0f, -2.0f));
  38. BOOST_CHECK_EQUAL(std::complex<float>(device_vector[3]), std::complex<float>(-2.0f, -1.0f));
  39. }
  40. // fills a vector of complex<float>'s on the device with a constant value
  41. BOOST_AUTO_TEST_CASE(fill_complex_vector)
  42. {
  43. boost::compute::vector<std::complex<float> > vector(6, context);
  44. boost::compute::fill(
  45. vector.begin(),
  46. vector.end(),
  47. std::complex<float>(2.0f, 5.0f),
  48. queue
  49. );
  50. queue.finish();
  51. BOOST_CHECK_EQUAL(std::complex<float>(vector[0]), std::complex<float>(2.0f, 5.0f));
  52. BOOST_CHECK_EQUAL(std::complex<float>(vector[1]), std::complex<float>(2.0f, 5.0f));
  53. BOOST_CHECK_EQUAL(std::complex<float>(vector[2]), std::complex<float>(2.0f, 5.0f));
  54. BOOST_CHECK_EQUAL(std::complex<float>(vector[3]), std::complex<float>(2.0f, 5.0f));
  55. BOOST_CHECK_EQUAL(std::complex<float>(vector[4]), std::complex<float>(2.0f, 5.0f));
  56. BOOST_CHECK_EQUAL(std::complex<float>(vector[5]), std::complex<float>(2.0f, 5.0f));
  57. }
  58. // extracts the real and imag components of a vector of complex<float>'s using
  59. // transform with the real() and imag() functions
  60. BOOST_AUTO_TEST_CASE(extract_real_and_imag)
  61. {
  62. boost::compute::vector<std::complex<float> > vector(context);
  63. vector.push_back(std::complex<float>(1.0f, 3.0f), queue);
  64. vector.push_back(std::complex<float>(3.0f, 1.0f), queue);
  65. vector.push_back(std::complex<float>(5.0f, -1.0f), queue);
  66. vector.push_back(std::complex<float>(7.0f, -3.0f), queue);
  67. vector.push_back(std::complex<float>(9.0f, -5.0f), queue);
  68. BOOST_CHECK_EQUAL(vector.size(), size_t(5));
  69. boost::compute::vector<float> reals(5, context);
  70. boost::compute::transform(
  71. vector.begin(),
  72. vector.end(),
  73. reals.begin(),
  74. boost::compute::real<float>(),
  75. queue
  76. );
  77. queue.finish();
  78. BOOST_CHECK_EQUAL(float(reals[0]), float(1.0f));
  79. BOOST_CHECK_EQUAL(float(reals[1]), float(3.0f));
  80. BOOST_CHECK_EQUAL(float(reals[2]), float(5.0f));
  81. BOOST_CHECK_EQUAL(float(reals[3]), float(7.0f));
  82. BOOST_CHECK_EQUAL(float(reals[4]), float(9.0f));
  83. boost::compute::vector<float> imags(5, context);
  84. boost::compute::transform(
  85. vector.begin(),
  86. vector.end(),
  87. imags.begin(),
  88. boost::compute::imag<float>(),
  89. queue
  90. );
  91. queue.finish();
  92. BOOST_CHECK_EQUAL(float(imags[0]), float(3.0f));
  93. BOOST_CHECK_EQUAL(float(imags[1]), float(1.0f));
  94. BOOST_CHECK_EQUAL(float(imags[2]), float(-1.0f));
  95. BOOST_CHECK_EQUAL(float(imags[3]), float(-3.0f));
  96. BOOST_CHECK_EQUAL(float(imags[4]), float(-5.0f));
  97. }
  98. // compute the complex conjugate of a vector of complex<float>'s
  99. BOOST_AUTO_TEST_CASE(complex_conj)
  100. {
  101. boost::compute::vector<std::complex<float> > input(context);
  102. input.push_back(std::complex<float>(1.0f, 3.0f), queue);
  103. input.push_back(std::complex<float>(3.0f, 1.0f), queue);
  104. input.push_back(std::complex<float>(5.0f, -1.0f), queue);
  105. input.push_back(std::complex<float>(7.0f, -3.0f), queue);
  106. input.push_back(std::complex<float>(9.0f, -5.0f), queue);
  107. BOOST_CHECK_EQUAL(input.size(), size_t(5));
  108. boost::compute::vector<std::complex<float> > output(5, context);
  109. boost::compute::transform(
  110. input.begin(),
  111. input.end(),
  112. output.begin(),
  113. boost::compute::conj<float>(),
  114. queue
  115. );
  116. queue.finish();
  117. BOOST_CHECK_EQUAL(std::complex<float>(output[0]), std::complex<float>(1.0f, -3.0f));
  118. BOOST_CHECK_EQUAL(std::complex<float>(output[1]), std::complex<float>(3.0f, -1.0f));
  119. BOOST_CHECK_EQUAL(std::complex<float>(output[2]), std::complex<float>(5.0f, 1.0f));
  120. BOOST_CHECK_EQUAL(std::complex<float>(output[3]), std::complex<float>(7.0f, 3.0f));
  121. BOOST_CHECK_EQUAL(std::complex<float>(output[4]), std::complex<float>(9.0f, 5.0f));
  122. }
  123. // check type_name() for std::complex
  124. BOOST_AUTO_TEST_CASE(complex_type_name)
  125. {
  126. BOOST_CHECK(
  127. std::strcmp(
  128. boost::compute::type_name<std::complex<float> >(),
  129. "float2"
  130. ) == 0
  131. );
  132. }
  133. BOOST_AUTO_TEST_CASE(transform_multiply)
  134. {
  135. boost::compute::vector<std::complex<float> > x(context);
  136. x.push_back(std::complex<float>(1.0f, 2.0f), queue);
  137. x.push_back(std::complex<float>(-2.0f, 5.0f), queue);
  138. boost::compute::vector<std::complex<float> > y(context);
  139. y.push_back(std::complex<float>(3.0f, 4.0f), queue);
  140. y.push_back(std::complex<float>(2.0f, -1.0f), queue);
  141. boost::compute::vector<std::complex<float> > z(2, context);
  142. // z = x * y
  143. boost::compute::transform(
  144. x.begin(),
  145. x.end(),
  146. y.begin(),
  147. z.begin(),
  148. boost::compute::multiplies<std::complex<float> >(),
  149. queue
  150. );
  151. queue.finish();
  152. BOOST_CHECK_EQUAL(std::complex<float>(z[0]), std::complex<float>(-5.0f, 10.0f));
  153. BOOST_CHECK_EQUAL(std::complex<float>(z[1]), std::complex<float>(1.0f, 12.0f));
  154. }
  155. BOOST_AUTO_TEST_SUITE_END()