//---------------------------------------------------------------------------// // 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://kylelutz.github.com/compute for more information. //---------------------------------------------------------------------------// #define BOOST_TEST_MODULE TestFill #include #include #include #include #include #include #include "check_macros.hpp" #include "context_setup.hpp" namespace bc = boost::compute; namespace compute = boost::compute; BOOST_AUTO_TEST_CASE(fill_int) { bc::vector vector(1000); bc::fill(vector.begin(), vector.end(), 0); bc::system::finish(); BOOST_CHECK_EQUAL(vector.front(), 0); BOOST_CHECK_EQUAL(vector.back(), 0); bc::fill(vector.begin(), vector.end(), 100); bc::system::finish(); BOOST_CHECK_EQUAL(vector.front(), 100); BOOST_CHECK_EQUAL(vector.back(), 100); bc::fill(vector.begin() + 500, vector.end(), 42); bc::system::finish(); BOOST_CHECK_EQUAL(vector.front(), 100); BOOST_CHECK_EQUAL(vector[499], 100); BOOST_CHECK_EQUAL(vector[500], 42); BOOST_CHECK_EQUAL(vector.back(), 42); } BOOST_AUTO_TEST_CASE(fill_int2) { using bc::int2_; bc::vector vector(10); bc::fill(vector.begin(), vector.end(), int2_(4, 2)); CHECK_RANGE_EQUAL(int2_, 10, vector, (int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2), int2_(4, 2)) ); bc::fill(vector.begin(), vector.end(), int2_(-2, -4)); CHECK_RANGE_EQUAL(int2_, 10, vector, (int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4), int2_(-2, -4)) ); } BOOST_AUTO_TEST_CASE(fill_n_float) { bc::vector vector(4); bc::fill_n(vector.begin(), 4, 1.5f); CHECK_RANGE_EQUAL(float, 4, vector, (1.5f, 1.5f, 1.5f, 1.5f)); bc::fill_n(vector.begin(), 3, 2.75f); CHECK_RANGE_EQUAL(float, 4, vector, (2.75f, 2.75f, 2.75f, 1.5f)); bc::fill_n(vector.begin() + 1, 2, -3.2f); CHECK_RANGE_EQUAL(float, 4, vector, (2.75f, -3.2f, -3.2f, 1.5f)); bc::fill_n(vector.begin(), 4, 0.0f); CHECK_RANGE_EQUAL(float, 4, vector, (0.0f, 0.0f, 0.0f, 0.0f)); } BOOST_AUTO_TEST_CASE(check_fill_type) { compute::vector vector(5, context); compute::future future = compute::fill_async(vector.begin(), vector.end(), 42, queue); future.wait(); #ifdef CL_VERSION_1_2 BOOST_CHECK_EQUAL( future.get_event().get_command_type(), device.check_version(1,2) ? CL_COMMAND_FILL_BUFFER : CL_COMMAND_NDRANGE_KERNEL ); #else BOOST_CHECK( future.get_event().get_command_type() == CL_COMMAND_NDRANGE_KERNEL ); #endif } BOOST_AUTO_TEST_CASE(fill_uchar4) { using compute::uchar4_; // fill vector with uchar4 pattern compute::vector vec(4, context); compute::fill(vec.begin(), vec.end(), uchar4_(32, 64, 128, 255), queue); // check results std::vector result(4); compute::copy(vec.begin(), vec.end(), result.begin(), queue); BOOST_CHECK_EQUAL(result[0], uchar4_(32, 64, 128, 255)); BOOST_CHECK_EQUAL(result[1], uchar4_(32, 64, 128, 255)); BOOST_CHECK_EQUAL(result[2], uchar4_(32, 64, 128, 255)); BOOST_CHECK_EQUAL(result[3], uchar4_(32, 64, 128, 255)); } BOOST_AUTO_TEST_CASE(fill_clone_buffer) { int data[] = { 1, 2, 3, 4 }; compute::vector vec(data, data + 4, queue); CHECK_RANGE_EQUAL(int, 4, vec, (1, 2, 3, 4)); compute::buffer cloned_buffer = vec.get_buffer().clone(queue); BOOST_CHECK( compute::equal( vec.begin(), vec.end(), compute::make_buffer_iterator(cloned_buffer, 0), queue ) ); compute::fill(vec.begin(), vec.end(), 5, queue); BOOST_CHECK( !compute::equal( vec.begin(), vec.end(), compute::make_buffer_iterator(cloned_buffer, 0), queue ) ); compute::fill( compute::make_buffer_iterator(cloned_buffer, 0), compute::make_buffer_iterator(cloned_buffer, 4), 5, queue ); BOOST_CHECK( compute::equal( vec.begin(), vec.end(), compute::make_buffer_iterator(cloned_buffer, 0), queue ) ); } BOOST_AUTO_TEST_CASE(fill_last_value) { compute::vector vec(4, context); compute::fill_n(vec.begin(), 4, 0, queue); CHECK_RANGE_EQUAL(int, 4, vec, (0, 0, 0, 0)); compute::fill_n(vec.end() - 1, 1, 7, queue); CHECK_RANGE_EQUAL(int, 4, vec, (0, 0, 0, 7)); } BOOST_AUTO_TEST_SUITE_END()