SeqAn3 3.4.0-rc.4
The Modern C++ library for sequence analysis.
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
aminoacid_base.hpp
Go to the documentation of this file.
1// SPDX-FileCopyrightText: 2006-2025 Knut Reinert & Freie Universität Berlin
2// SPDX-FileCopyrightText: 2016-2025 Knut Reinert & MPI für molekulare Genetik
3// SPDX-License-Identifier: BSD-3-Clause
4
10#pragma once
11
17
18namespace seqan3
19{
20
28template <typename derived_type, auto size>
29class aminoacid_base : public aminoacid_empty_base, public alphabet_base<derived_type, size, char>
30{
31private:
34
36 friend base_t;
37
41 constexpr aminoacid_base() noexcept = default;
42 constexpr aminoacid_base(aminoacid_base const &) noexcept = default;
43 constexpr aminoacid_base(aminoacid_base &&) noexcept = default;
44 constexpr aminoacid_base & operator=(aminoacid_base const &) noexcept = default;
45 constexpr aminoacid_base & operator=(aminoacid_base &&) noexcept = default;
46 ~aminoacid_base() noexcept = default;
47
49
52
53protected:
54 // Import from base:
55 using typename base_t::char_type;
56 using typename base_t::rank_type;
57
58public:
59 using base_t::alphabet_size;
60 using base_t::to_rank;
61
65 // This constructor needs to be public, because constructor templates are not inherited otherwise
70 template <typename other_aa_type>
71 requires (!std::same_as<aminoacid_base, other_aa_type>) && (!std::same_as<derived_type, other_aa_type>)
72 && aminoacid_alphabet<other_aa_type>
74 explicit constexpr aminoacid_base(other_aa_type const other) noexcept
75 {
76 if constexpr (is_constexpr_default_constructible_v<other_aa_type>
77 && detail::writable_constexpr_alphabet<other_aa_type>)
78 {
79 static_cast<derived_type &>(*this) =
80 detail::convert_through_char_representation<other_aa_type, derived_type>[seqan3::to_rank(other)];
81 }
82 else
83 {
84 seqan3::assign_char_to(seqan3::to_char(other), static_cast<derived_type &>(*this));
85 }
86 }
88
108 static constexpr bool char_is_valid(char_type const c) noexcept
109 {
110 return valid_char_table[static_cast<uint8_t>(c)];
111 }
112
113private:
116 []() constexpr
117 {
119
120 ret.fill(false); // Default constructor does not initialise!
121
122 // the original valid chars and their lower cases
123 for (size_t rank = 0u; rank < derived_type::alphabet_size; ++rank)
124 {
125 uint8_t c = derived_type::rank_to_char(rank);
126 ret[c] = true;
127 ret[to_lower(c)] = true;
128 }
129
130 return ret;
131 }()};
132};
133
134} // namespace seqan3
Provides seqan3::aminoacid_alphabet.
Provides alphabet helper concepts.
Provides seqan3::detail::convert_through_char_representation.
Provides seqan3::alphabet_base.
A CRTP-base that makes defining a custom alphabet easier.
Definition alphabet_base.hpp:54
constexpr rank_type to_rank() const noexcept
Return the letter's numeric value (rank in the alphabet).
Definition alphabet_base.hpp:134
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:196
rank_type rank
The value of the alphabet letter is stored as the rank.
Definition alphabet_base.hpp:258
A CRTP-base that refines seqan3::alphabet_base and is used by the amino acids.
Definition aminoacid_base.hpp:30
static constexpr std::array< bool, 256 > valid_char_table
Implementation of seqan3::aminoacid_base::char_is_valid().
Definition aminoacid_base.hpp:115
friend derived_type
Befriend the derived class so it can instantiate.
Definition aminoacid_base.hpp:51
constexpr aminoacid_base() noexcept=default
Defaulted.
friend base_t
Befriend the base class.
Definition aminoacid_base.hpp:36
static constexpr bool char_is_valid(char_type const c) noexcept
Validate whether a character value has a one-to-one mapping to an alphabet value.
Definition aminoacid_base.hpp:108
T fill(T... args)
constexpr auto assign_char_to
Assign a character to an alphabet object.
Definition alphabet/concept.hpp:517
constexpr auto to_char
Return the char representation of an alphabet object.
Definition alphabet/concept.hpp:381
constexpr auto to_rank
Return the rank representation of a (semi-)alphabet object.
Definition alphabet/concept.hpp:152
A concept that indicates whether an alphabet represents amino acids.
Checks whether from_t can be converted through to_t using their char representation.
The main SeqAn3 namespace.
Definition aligned_sequence_concept.hpp:26
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:74
SeqAn specific customisations in the standard namespace.
This is an empty base class that can be inherited by types that shall model seqan3::aminoacid_alphabe...
Definition alphabet/aminoacid/concept.hpp:32
Provides utilities for modifying characters.
Hide me