109 ret[rank_to_char_table[rnk]] = rnk;
110 ret[
to_lower(rank_to_char_table[rnk])] = rnk;
114 ret[
'U'] = ret[
'T']; ret[
'u'] = ret[
't'];
144 return rank_complement_table[rank];
153 return rank_to_char_table[rank];
160 return char_to_rank_table[
static_cast<index_t
>(chr)];
175 #ifdef SEQAN3_DEPRECATED_310
186 inline namespace literals
203 constexpr
dna16sam operator""_dna16sam(
char const c) noexcept
224 for (
size_t i = 0; i < n; ++i)
225 r[i].assign_char(s[i]);
230 #ifdef SEQAN3_DEPRECATED_310
234 return seqan3::operator
""_dna16sam(c);
240 return seqan3::operator
""_dna16sam(s, n);
A CRTP-base that makes defining a custom alphabet easier.
Definition: alphabet_base.hpp:81
detail::min_viable_uint_t< size - 1 > rank_type
The type of the alphabet when represented as a number (e.g. via to_rank()).
Definition: alphabet_base.hpp:104
constexpr derived_type & assign_char(char_type const chr) noexcept
Assign from a character, implicitly converts invalid characters.
Definition: alphabet_base.hpp:211
static constexpr detail::min_viable_uint_t< size > alphabet_size
The size of the alphabet, i.e. the number of different values it can take.
Definition: alphabet_base.hpp:276
std::conditional_t< std::same_as< char_t, void >, char, char_t > char_type
The char representation; conditional needed to make semi alphabet definitions legal.
Definition: alphabet_base.hpp:96
A 16 letter DNA alphabet, containing all IUPAC symbols minus the gap and plus an equality sign ('=').
Definition: dna16sam.hpp:48
constexpr dna16sam() noexcept=default
Defaulted.
A CRTP-base that refines seqan3::alphabet_base and is used by the nucleotides.
Definition: nucleotide_base.hpp:57
The main SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29
dna16sam_vector sam_dna16_vector
Definition: dna16sam.hpp:180
constexpr char_type to_lower(char_type const c) noexcept
Converts 'A'-'Z' to 'a'-'z' respectively; other characters are returned as is.
Definition: transform.hpp:81
Provides seqan3::nucleotide_base.