/*============================================================================= Copyright (c) 2011-2014 Bolero MURAKAMI https://github.com/bolero-MURAKAMI/Sprout 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) =============================================================================*/ #ifndef SPROUT_RANGE_NUMERIC_CXX14_PARTIAL_SUM_HPP #define SPROUT_RANGE_NUMERIC_CXX14_PARTIAL_SUM_HPP #include #include #include #include #include #include namespace sprout { namespace range { // // partial_sum // template< typename InputRange, typename OutputIterator, typename sprout::enabler_if::value>::type = sprout::enabler > inline SPROUT_CONSTEXPR OutputIterator partial_sum(InputRange const& rng, OutputIterator result) { return sprout::partial_sum(sprout::begin(rng), sprout::end(rng), result); } template< typename InputRange, typename OutputIterator, typename BinaryOperation, typename sprout::enabler_if::value>::type = sprout::enabler > inline SPROUT_CONSTEXPR OutputIterator partial_sum(InputRange const& rng, OutputIterator result, BinaryOperation binary_op) { return sprout::partial_sum(sprout::begin(rng), sprout::end(rng), result, binary_op); } } // namespace range } // namespace sprout #endif // #ifndef SPROUT_RANGE_NUMERIC_CXX14_PARTIAL_SUM_HPP