28namespace seqan3::detail
46template <std::ranges::random_access_range urng_t, std::ranges::random_access_range inserted_rng_t>
47 requires std::ranges::view<urng_t> && std::ranges::sized_range<urng_t> && std::ranges::view<inserted_rng_t>
48 && std::ranges::sized_range<inserted_rng_t>
49 && std::common_reference_with<std::ranges::range_reference_t<urng_t>,
50 std::ranges::range_reference_t<inserted_rng_t>>
51class view_interleave :
public std::ranges::view_interface<view_interleave<urng_t, inserted_rng_t>>
59 inserted_rng_t inserted_range;
66 using size_type = std::ranges::range_size_t<urng_t>;
71 using const_reference =
72 detail::transformation_trait_or_t<std::common_reference<std::ranges::range_reference_t<urng_t const>,
73 std::ranges::range_reference_t<inserted_rng_t const>>,
76 using value_type = std::ranges::range_value_t<urng_t>;
78 using difference_type = std::ranges::range_difference_t<urng_t>;
80 using iterator = detail::random_access_iterator<view_interleave>;
82 using const_iterator = detail::random_access_iterator<view_interleave const>;
86 template <
typename range_type,
template <
typename...>
typename derived_t_template>
87 friend class detail::random_access_iterator_base;
93 constexpr view_interleave() noexcept = default;
94 constexpr view_interleave(view_interleave const & rhs) noexcept = default;
95 constexpr view_interleave(view_interleave && rhs) noexcept = default;
96 constexpr view_interleave & operator=(view_interleave const & rhs) noexcept = default;
97 constexpr view_interleave & operator=(view_interleave && rhs) noexcept = default;
98 ~view_interleave() noexcept = default;
105 explicit constexpr view_interleave(urng_t && _urange,
size_t const _step_size, inserted_rng_t && _inserted_range) :
107 step_size{_step_size},
108 inserted_range{std::forward<inserted_rng_t>(_inserted_range)}
120 template <
typename orng_t,
typename oirng_t>
121 requires std::constructible_from<urng_t, decltype(views::type_reduce(std::declval<orng_t>()))>
122 && std::constructible_from<inserted_rng_t, seqan3::detail::all_t<oirng_t>>
123 explicit constexpr view_interleave(orng_t && _urange,
size_t const _step_size, oirng_t && _inserted_range) :
146 iterator
begin() noexcept
152 const_iterator
begin() const noexcept
170 iterator
end() noexcept
172 return {*
this,
size()};
176 const_iterator
end() const noexcept
178 return {*
this,
size()};
192 return std::ranges::size(urange)
193 + ((
std::floor(std::ranges::size(urange) / step_size)
194 - (std::ranges::size(urange) % step_size == 0 ? 1 : 0))
195 * std::ranges::size(inserted_range));
199 size_type
size()
const
201 return std::ranges::size(urange)
202 + ((
std::floor(std::ranges::size(urange) / step_size)
203 - (std::ranges::size(urange) % step_size == 0 ? 1 : 0))
204 * std::ranges::size(inserted_range));
222 reference operator[](size_type
const i)
224 size_t combined_size = step_size + std::ranges::size(inserted_range);
226 if (i % (combined_size) < step_size)
227 return urange[i - (
std::floor(i / (combined_size)) * std::ranges::size(inserted_range))];
229 return inserted_range[(i % (combined_size)) - step_size];
233 const_reference operator[](size_type
const i)
const
235 size_t combined_size = step_size + std::ranges::size(inserted_range);
237 if (i % (combined_size) < step_size)
238 return urange[i - (
std::floor(i / (combined_size)) * std::ranges::size(inserted_range))];
240 return inserted_range[(i % (combined_size)) - step_size];
246template <std::ranges::random_access_range urng_t, std::ranges::random_access_range inserted_rng_t>
247 requires std::ranges::viewable_range<urng_t> && std::ranges::sized_range<urng_t>
248 && std::ranges::sized_range<inserted_rng_t>
249 && std::common_reference_with<std::ranges::range_reference_t<urng_t>,
250 std::ranges::range_reference_t<inserted_rng_t>>
251 view_interleave(urng_t &&,
size_t, inserted_rng_t &&)
252 -> view_interleave<decltype(views::type_reduce(std::declval<urng_t>())),
253 seqan3::detail::all_t<inserted_rng_t>>;
264 template <std::ranges::forward_range inserted_rng_t, std::
integral
size_type>
265 constexpr auto operator()(size_type
const size, inserted_rng_t && i)
const noexcept
267 return detail::adaptor_from_functor{*
this,
size, std::forward<inserted_rng_t>(i)};
276 template <std::ranges::range urng_t, std::ranges::range inserted_rng_t, std::
integral
size_type>
277 constexpr auto operator()(urng_t && urange, size_type
const size, inserted_rng_t && i)
const noexcept
279 static_assert(std::ranges::forward_range<urng_t>,
280 "The underlying range parameter in views::interleave must model std::ranges::forward_range.");
281 static_assert(std::ranges::viewable_range<urng_t>,
282 "The underlying range parameter in views::interleave must model std::ranges::viewable_range.");
283 static_assert(std::ranges::forward_range<inserted_rng_t>,
284 "The range to be inserted by views::interleave must model std::ranges::forward_range.");
285 if constexpr (std::ranges::random_access_range<urng_t> && std::ranges::sized_range<urng_t>
286 && std::ranges::random_access_range<inserted_rng_t> && std::ranges::sized_range<inserted_rng_t>)
288 return detail::view_interleave{std::forward<urng_t>(urange),
289 static_cast<size_t>(
size),
290 std::forward<inserted_rng_t>(i)};
Provides seqan3::detail::adaptor_from_functor.
Provides seqan3::detail::all.
Provides seqan3::views::chunk.
constexpr size_t size
The size of a type pack.
Definition: type_pack/traits.hpp:146
seqan::std::views::join_with join_with
A view adaptor that represents view consisting of the sequence obtained from flattening a view of ran...
Definition: join_with.hpp:28
seqan::std::views::chunk chunk
A view adaptor that divides a range into chunks. <dl class="no-api">This entity is not part of the Se...
Definition: chunk.hpp:26
constexpr auto type_reduce
A view adaptor that behaves like std::views::all, but type erases certain ranges.
Definition: type_reduce.hpp:150
constexpr auto interleave
A view that interleaves a given range into another range at regular intervals.
Definition: interleave.hpp:379
Provides seqan3::views::join_with.
The SeqAn namespace for views.
Definition: char_strictly_to.hpp:22
The main SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29
SeqAn specific customisations in the standard namespace.
Provides the seqan3::detail::random_access_iterator class.
Provides seqan3::views::type_reduce.