/* * Copyright 2008-2012 NVIDIA Corporation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #pragma once #include #include #include #include #include #include #include namespace thrust { namespace system { namespace detail { namespace generic { template OutputIterator transform_inclusive_scan(thrust::execution_policy &exec, InputIterator first, InputIterator last, OutputIterator result, UnaryFunction unary_op, BinaryFunction binary_op) { // the pseudocode for deducing the type of the temporary used below: // // if UnaryFunction is AdaptableUnaryFunction // TemporaryType = AdaptableUnaryFunction::result_type // else if OutputIterator is a "pure" output iterator // TemporaryType = InputIterator::value_type // else // TemporaryType = OutputIterator::value_type // // XXX upon c++0x, TemporaryType needs to be: // result_of::type typedef typename thrust::detail::eval_if< thrust::detail::has_result_type::value, thrust::detail::result_type, thrust::detail::eval_if< thrust::detail::is_output_iterator::value, thrust::iterator_value, thrust::iterator_value > >::type ValueType; thrust::transform_iterator _first(first, unary_op); thrust::transform_iterator _last(last, unary_op); return thrust::inclusive_scan(exec, _first, _last, result, binary_op); } // end transform_inclusive_scan() template OutputIterator transform_exclusive_scan(thrust::execution_policy &exec, InputIterator first, InputIterator last, OutputIterator result, UnaryFunction unary_op, T init, AssociativeOperator binary_op) { // the pseudocode for deducing the type of the temporary used below: // // if UnaryFunction is AdaptableUnaryFunction // TemporaryType = AdaptableUnaryFunction::result_type // else if OutputIterator is a "pure" output iterator // TemporaryType = InputIterator::value_type // else // TemporaryType = OutputIterator::value_type // // XXX upon c++0x, TemporaryType needs to be: // result_of::type typedef typename thrust::detail::eval_if< thrust::detail::has_result_type::value, thrust::detail::result_type, thrust::detail::eval_if< thrust::detail::is_output_iterator::value, thrust::iterator_value, thrust::iterator_value > >::type ValueType; thrust::transform_iterator _first(first, unary_op); thrust::transform_iterator _last(last, unary_op); return thrust::exclusive_scan(exec, _first, _last, result, init, binary_op); } // end transform_exclusive_scan() } // end namespace generic } // end namespace detail } // end namespace system } // end namespace thrust