25namespace seqan3::detail
44struct max_score_updater_simd_global
63 template <
typename score_t,
typename coordinate_t>
64 requires (std::assignable_from<score_t &, score_t const &> &&
65 requires (coordinate_t coordinate)
67 requires simd_concept<
decltype(coordinate.col)>;
68 requires simd_concept<
decltype(coordinate.row)>;
70 void operator()(score_t & optimal_score,
71 coordinate_t
const & optimal_coordinate,
72 score_t current_score,
73 coordinate_t
const & current_coordinate)
const noexcept
76 (optimal_coordinate.col == current_coordinate.col) && (optimal_coordinate.row == current_coordinate.row);
77 optimal_score = (mask) ? std::move(current_score) : optimal_score;
85template <
typename alignment_configuration_t, std::semiregular optimum_updater_t>
86 requires is_type_specialisation_of_v<alignment_configuration_t, configuration>
89 typename alignment_configuration_traits<alignment_configuration_t>::score_type &,
90 typename alignment_configuration_traits<alignment_configuration_t>::matrix_coordinate_type &,
91 typename alignment_configuration_traits<alignment_configuration_t>::score_type,
92 typename alignment_configuration_traits<alignment_configuration_t>::matrix_coordinate_type>
93class policy_optimum_tracker_simd :
protected policy_optimum_tracker<alignment_configuration_t, optimum_updater_t>
97 using base_policy_t = policy_optimum_tracker<alignment_configuration_t, optimum_updater_t>;
100 using typename base_policy_t::score_type;
101 using typename base_policy_t::traits_type;
104 using scalar_type =
typename simd::simd_traits<score_type>::scalar_type;
106 using original_score_type =
typename traits_type::original_score_type;
108 static_assert(simd_concept<score_type>,
"Must be a simd type!");
111 using base_policy_t::compare_and_set_optimum;
112 using base_policy_t::optimal_coordinate;
113 using base_policy_t::optimal_score;
120 policy_optimum_tracker_simd() =
default;
121 policy_optimum_tracker_simd(policy_optimum_tracker_simd
const &) =
default;
122 policy_optimum_tracker_simd(policy_optimum_tracker_simd &&) =
default;
123 policy_optimum_tracker_simd & operator=(policy_optimum_tracker_simd
const &) =
default;
124 policy_optimum_tracker_simd & operator=(policy_optimum_tracker_simd &&) =
default;
125 ~policy_optimum_tracker_simd() =
default;
135 policy_optimum_tracker_simd(alignment_configuration_t
const & config) : base_policy_t{config}
137 base_policy_t::test_last_row_cell =
true;
138 base_policy_t::test_last_column_cell =
true;
194 template <std::ranges::input_range sequence1_collection_t, std::ranges::input_range sequence2_collection_t>
195 void initialise_tracker(sequence1_collection_t & sequence1_collection,
196 sequence2_collection_t & sequence2_collection)
198 using index_t =
typename traits_type::matrix_index_type;
199 using scalar_index_t =
typename simd_traits<index_t>::scalar_type;
201 scalar_index_t largest_sequence1_size{};
202 scalar_index_t largest_sequence2_size{};
207 size_t sequence_count{};
208 for (
auto && [sequence1, sequence2] :
views::zip(sequence1_collection, sequence2_collection))
210 sequence1_sizes[sequence_count] = std::ranges::distance(sequence1);
211 sequence2_sizes[sequence_count] = std::ranges::distance(sequence2);
212 largest_sequence1_size =
std::max(largest_sequence1_size, sequence1_sizes[sequence_count]);
213 largest_sequence2_size =
std::max(largest_sequence2_size, sequence2_sizes[sequence_count]);
220 for (
size_t index = 0; index != sequence_count; ++index)
222 assert(sequence1_sizes[index] <= largest_sequence1_size);
223 assert(sequence2_sizes[index] <= largest_sequence2_size);
225 padding_offsets[index] =
std::min(largest_sequence1_size - sequence1_sizes[index],
226 largest_sequence2_size - sequence2_sizes[index]);
227 sequence1_sizes[index] += padding_offsets[index];
228 sequence2_sizes[index] += padding_offsets[index];
232 optimal_coordinate.col = simd::load<index_t>(sequence1_sizes.data());
233 optimal_coordinate.row = simd::load<index_t>(sequence2_sizes.data());
Provides algorithms to modify seqan3::simd::simd_type.
seqan::std::views::zip zip
A view adaptor that takes several views and returns tuple-like values from every i-th element of each...
Definition: zip.hpp:27
Provides lazy template instantiation traits.
Provides seqan3::detail::policy_optimum_tracker.
Provides seqan3::simd::simd_type.
Provides seqan3::simd::simd_traits.
Provides seqan3::views::zip.