//---------------------------------------------------------------------------// // Copyright (c) 2013 Kyle Lutz // // Distributed under the Boost Software License, Version 1.0 // See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt // // See http://boostorg.github.com/compute for more information. //---------------------------------------------------------------------------// #define BOOST_TEST_MODULE TestComplex #include #include #include #include #include #include #include #include "context_setup.hpp" // copies a vector of complex's on the host to the device BOOST_AUTO_TEST_CASE(copy_complex_vector) { std::vector > host_vector; host_vector.push_back(std::complex(1.0f, 2.0f)); host_vector.push_back(std::complex(-2.0f, 1.0f)); host_vector.push_back(std::complex(1.0f, -2.0f)); host_vector.push_back(std::complex(-2.0f, -1.0f)); boost::compute::vector > device_vector(context); boost::compute::copy( host_vector.begin(), host_vector.end(), device_vector.begin(), queue ); queue.finish(); BOOST_CHECK_EQUAL(std::complex(device_vector[0]), std::complex(1.0f, 2.0f)); BOOST_CHECK_EQUAL(std::complex(device_vector[1]), std::complex(-2.0f, 1.0f)); BOOST_CHECK_EQUAL(std::complex(device_vector[2]), std::complex(1.0f, -2.0f)); BOOST_CHECK_EQUAL(std::complex(device_vector[3]), std::complex(-2.0f, -1.0f)); } // fills a vector of complex's on the device with a constant value BOOST_AUTO_TEST_CASE(fill_complex_vector) { boost::compute::vector > vector(6, context); boost::compute::fill( vector.begin(), vector.end(), std::complex(2.0f, 5.0f), queue ); queue.finish(); BOOST_CHECK_EQUAL(std::complex(vector[0]), std::complex(2.0f, 5.0f)); BOOST_CHECK_EQUAL(std::complex(vector[1]), std::complex(2.0f, 5.0f)); BOOST_CHECK_EQUAL(std::complex(vector[2]), std::complex(2.0f, 5.0f)); BOOST_CHECK_EQUAL(std::complex(vector[3]), std::complex(2.0f, 5.0f)); BOOST_CHECK_EQUAL(std::complex(vector[4]), std::complex(2.0f, 5.0f)); BOOST_CHECK_EQUAL(std::complex(vector[5]), std::complex(2.0f, 5.0f)); } // extracts the real and imag components of a vector of complex's using // transform with the real() and imag() functions BOOST_AUTO_TEST_CASE(extract_real_and_imag) { boost::compute::vector > vector(context); vector.push_back(std::complex(1.0f, 3.0f), queue); vector.push_back(std::complex(3.0f, 1.0f), queue); vector.push_back(std::complex(5.0f, -1.0f), queue); vector.push_back(std::complex(7.0f, -3.0f), queue); vector.push_back(std::complex(9.0f, -5.0f), queue); BOOST_CHECK_EQUAL(vector.size(), size_t(5)); boost::compute::vector reals(5, context); boost::compute::transform( vector.begin(), vector.end(), reals.begin(), boost::compute::real(), queue ); queue.finish(); BOOST_CHECK_EQUAL(float(reals[0]), float(1.0f)); BOOST_CHECK_EQUAL(float(reals[1]), float(3.0f)); BOOST_CHECK_EQUAL(float(reals[2]), float(5.0f)); BOOST_CHECK_EQUAL(float(reals[3]), float(7.0f)); BOOST_CHECK_EQUAL(float(reals[4]), float(9.0f)); boost::compute::vector imags(5, context); boost::compute::transform( vector.begin(), vector.end(), imags.begin(), boost::compute::imag(), queue ); queue.finish(); BOOST_CHECK_EQUAL(float(imags[0]), float(3.0f)); BOOST_CHECK_EQUAL(float(imags[1]), float(1.0f)); BOOST_CHECK_EQUAL(float(imags[2]), float(-1.0f)); BOOST_CHECK_EQUAL(float(imags[3]), float(-3.0f)); BOOST_CHECK_EQUAL(float(imags[4]), float(-5.0f)); } // compute the complex conjugate of a vector of complex's BOOST_AUTO_TEST_CASE(complex_conj) { boost::compute::vector > input(context); input.push_back(std::complex(1.0f, 3.0f), queue); input.push_back(std::complex(3.0f, 1.0f), queue); input.push_back(std::complex(5.0f, -1.0f), queue); input.push_back(std::complex(7.0f, -3.0f), queue); input.push_back(std::complex(9.0f, -5.0f), queue); BOOST_CHECK_EQUAL(input.size(), size_t(5)); boost::compute::vector > output(5, context); boost::compute::transform( input.begin(), input.end(), output.begin(), boost::compute::conj(), queue ); queue.finish(); BOOST_CHECK_EQUAL(std::complex(output[0]), std::complex(1.0f, -3.0f)); BOOST_CHECK_EQUAL(std::complex(output[1]), std::complex(3.0f, -1.0f)); BOOST_CHECK_EQUAL(std::complex(output[2]), std::complex(5.0f, 1.0f)); BOOST_CHECK_EQUAL(std::complex(output[3]), std::complex(7.0f, 3.0f)); BOOST_CHECK_EQUAL(std::complex(output[4]), std::complex(9.0f, 5.0f)); } // check type_name() for std::complex BOOST_AUTO_TEST_CASE(complex_type_name) { BOOST_CHECK( std::strcmp( boost::compute::type_name >(), "float2" ) == 0 ); } BOOST_AUTO_TEST_CASE(transform_multiply) { boost::compute::vector > x(context); x.push_back(std::complex(1.0f, 2.0f), queue); x.push_back(std::complex(-2.0f, 5.0f), queue); boost::compute::vector > y(context); y.push_back(std::complex(3.0f, 4.0f), queue); y.push_back(std::complex(2.0f, -1.0f), queue); boost::compute::vector > z(2, context); // z = x * y boost::compute::transform( x.begin(), x.end(), y.begin(), z.begin(), boost::compute::multiplies >(), queue ); queue.finish(); BOOST_CHECK_EQUAL(std::complex(z[0]), std::complex(-5.0f, 10.0f)); BOOST_CHECK_EQUAL(std::complex(z[1]), std::complex(1.0f, 12.0f)); } BOOST_AUTO_TEST_SUITE_END()