//---------------------------------------------------------------------------// // 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 TestFunctionalUnpack #include #include #include #include #include #include #include #include "check_macros.hpp" #include "context_setup.hpp" namespace compute = boost::compute; BOOST_AUTO_TEST_CASE(plus_int) { int data1[] = { 1, 3, 5, 7 }; int data2[] = { 2, 4, 6, 8 }; compute::vector input1(4, context); compute::vector input2(4, context); compute::copy_n(data1, 4, input1.begin(), queue); compute::copy_n(data2, 4, input2.begin(), queue); compute::vector output(4, context); compute::transform( compute::make_zip_iterator( boost::make_tuple(input1.begin(), input2.begin()) ), compute::make_zip_iterator( boost::make_tuple(input1.end(), input2.end()) ), output.begin(), compute::detail::unpack(compute::plus()), queue ); CHECK_RANGE_EQUAL(int, 4, output, (3, 7, 11, 15)); } BOOST_AUTO_TEST_CASE(fma_float) { float data1[] = { 1, 3, 5, 7 }; float data2[] = { 2, 4, 6, 8 }; float data3[] = { 0, 9, 1, 2 }; compute::vector input1(4, context); compute::vector input2(4, context); compute::vector input3(4, context); compute::copy_n(data1, 4, input1.begin(), queue); compute::copy_n(data2, 4, input2.begin(), queue); compute::copy_n(data3, 4, input3.begin(), queue); compute::vector output(4, context); compute::transform( compute::make_zip_iterator( boost::make_tuple(input1.begin(), input2.begin(), input3.begin()) ), compute::make_zip_iterator( boost::make_tuple(input1.end(), input2.end(), input3.begin()) ), output.begin(), compute::detail::unpack(compute::fma()), queue ); } BOOST_AUTO_TEST_CASE(subtract_int2) { using compute::int2_; int data[] = { 4, 2, 5, 1, 6, 3, 7, 0 }; compute::vector input(4, context); compute::copy_n(reinterpret_cast(data), 4, input.begin(), queue); compute::vector output(4, context); compute::transform( input.begin(), input.end(), output.begin(), compute::detail::unpack(compute::minus()), queue ); CHECK_RANGE_EQUAL(int, 4, output, (2, 4, 3, 7)); } BOOST_AUTO_TEST_SUITE_END()