17namespace seqan3::detail
28template <
typename word_t,
typename score_t,
bool is_semi_global,
bool use_max_errors>
29class edit_distance_score_matrix_full
33 template <std::ranges::viewable_range database_t,
34 std::ranges::viewable_range query_t,
35 typename align_config_t,
37 friend class edit_distance_unbanded;
42 edit_distance_score_matrix_full() =
default;
43 edit_distance_score_matrix_full(edit_distance_score_matrix_full
const &) =
default;
44 edit_distance_score_matrix_full(edit_distance_score_matrix_full &&) =
default;
45 edit_distance_score_matrix_full & operator=(edit_distance_score_matrix_full
const &) =
default;
46 edit_distance_score_matrix_full & operator=(edit_distance_score_matrix_full &&) =
default;
47 ~edit_distance_score_matrix_full() =
default;
51 template <
typename derived_t,
typename edit_traits>
52 friend class edit_distance_unbanded_score_matrix_policy;
57 edit_distance_score_matrix_full(
size_t const rows_size) : rows_size{rows_size}, columns{}
63 using word_type = word_t;
66 static constexpr auto word_size = bits_of<word_type>;
69 using score_type = score_t;
75 using reference = value_type;
78 using size_type = size_t;
91 void reserve(
size_t const new_capacity)
93 columns.reserve(new_capacity);
104 template <
typename score_type>
105 static size_t max_rows(word_type
const score_mask,
106 unsigned const last_block,
107 score_type
const score,
108 score_type
const max_errors)
noexcept
111 size_t const active_row = word_size * last_block +
offset;
112 return active_row + (score <= max_errors);
120 static score_type score_delta_of_word(word_type
const & vp, word_type
const & vn)
noexcept
129 reference
at(matrix_coordinate
const & coordinate)
const noexcept
131 size_t col = coordinate.col;
132 size_t row = coordinate.row;
134 assert(row < rows());
135 assert(col < cols());
137 column_type
const & column = columns[col];
138 if constexpr (use_max_errors)
139 if (!(row < column.max_rows))
142 score_type score = is_semi_global ? 0u :
static_cast<score_type
>(col);
144 size_t current_row = 1u;
145 size_t word_idx = 0u;
147 for (; current_row + word_size <= row; ++word_idx, current_row += word_size)
148 score += score_delta_of_word(column.vp[word_idx], column.vn[word_idx]);
150 if (row >= current_row)
152 word_type
const mask = (1u << (row - current_row + 1u)) - 1u;
153 score += score_delta_of_word(column.vp[word_idx] & mask, column.vn[word_idx] & mask);
160 size_t rows() const noexcept
166 size_t cols() const noexcept
168 return columns.size();
173 struct max_errors_state
181 struct score_matrix_state
190 struct column_type : enable_state_t<true, score_matrix_state>, enable_state_t<use_max_errors, max_errors_state>
198 requires (!use_max_errors)
200 column_type column{};
201 column.vp = std::move(vp);
202 column.vn = std::move(vn);
204 columns.push_back(std::move(column));
213 requires use_max_errors
215 column_type column{};
216 column.vp = std::move(vp);
217 column.vn = std::move(vn);
218 column.max_rows = max_rows;
220 columns.push_back(std::move(column));
Provides utility functions for bit twiddling.
Forwards for seqan3::edit_distance_unbanded related types.
@ offset
Sequence (seqan3::field::seq) relative start position (0-based), unsigned value.
typename decltype(detail::at< idx >(list_t{}))::type at
Return the type at given index from the type list.
Definition type_list/traits.hpp:276