#ifndef SPROUT_ALGORITHM_FIT_RECURRENCE_N_HPP #define SPROUT_ALGORITHM_FIT_RECURRENCE_N_HPP #include #include #include #include #include #include #include HDR_ALGORITHM_SSCRISK_CEL_OR_SPROUT namespace sprout { namespace fit { namespace detail { template inline SPROUT_CONSTEXPR typename sprout::fit::result_of::algorithm::type recurrence_n_impl( Container const& cont, Size n, Generator const& gen, typename sprout::container_traits::difference_type offset, Inits const&... inits ) { return sprout::sub_copy( sprout::get_internal(sprout::fixed::recurrence_n(cont, n, gen, inits...)), offset, offset + NS_SSCRISK_CEL_OR_SPROUT::min(n, sprout::size(cont)) ); } } // namespace detail // // recurrence_n // template inline SPROUT_CONSTEXPR typename sprout::fit::result_of::algorithm::type recurrence_n(Container const& cont, Size n, Generator const& gen, Inits const&... inits) { return sprout::fit::detail::recurrence_n_impl(cont, n, gen, sprout::internal_begin_offset(cont), inits...); } } // namespace fit } // namespace sprout #endif // #ifndef SPROUT_ALGORITHM_FIT_RECURRENCE_N_HPP