//---------------------------------------------------------------------------// // 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. //---------------------------------------------------------------------------// #ifndef BOOST_COMPUTE_ALGORITHM_SERIAL_MERGE_HPP #define BOOST_COMPUTE_ALGORITHM_SERIAL_MERGE_HPP #include #include #include #include namespace boost { namespace compute { namespace detail { template inline OutputIterator serial_merge(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp, command_queue &queue) { typedef typename std::iterator_traits::value_type input_type1; typedef typename std::iterator_traits::value_type input_type2; typedef typename std::iterator_traits::difference_type result_difference_type; std::ptrdiff_t size1 = std::distance(first1, last1); std::ptrdiff_t size2 = std::distance(first2, last2); meta_kernel k("serial_merge"); k.add_set_arg("size1", static_cast(size1)); k.add_set_arg("size2", static_cast(size2)); k << "uint i = 0;\n" << // index in result range "uint j = 0;\n" << // index in first input range "uint k = 0;\n" << // index in second input range // fetch initial values from each range k.decl("j_value") << " = " << first1[0] << ";\n" << k.decl("k_value") << " = " << first2[0] << ";\n" << // merge values from both input ranges to the result range "while(j < size1 && k < size2){\n" << " if(" << comp(k.var("j_value"), k.var("k_value")) << "){\n" << " " << result[k.var("i++")] << " = j_value;\n" << " j_value = " << first1[k.var("++j")] << ";\n" << " }\n" << " else{\n" " " << result[k.var("i++")] << " = k_value;\n" " k_value = " << first2[k.var("++k")] << ";\n" << " }\n" "}\n" // copy any remaining values from first range "while(j < size1){\n" << result[k.var("i++")] << " = " << first1[k.var("j++")] << ";\n" << "}\n" // copy any remaining values from second range "while(k < size2){\n" << result[k.var("i++")] << " = " << first2[k.var("k++")] << ";\n" << "}\n"; // run kernel k.exec(queue); return result + static_cast(size1 + size2); } } // end detail namespace } // end compute namespace } // end boost namespace #endif // BOOST_COMPUTE_ALGORITHM_SERIAL_MERGE_HPP