SeqAn3 3.1.0
The Modern C++ library for sequence analysis.
structured_aa.hpp
Go to the documentation of this file.
1// -----------------------------------------------------------------------------------------------------
2// Copyright (c) 2006-2021, Knut Reinert & Freie Universität Berlin
3// Copyright (c) 2016-2021, Knut Reinert & MPI für molekulare Genetik
4// This file may be used, modified and/or redistributed under the terms of the 3-clause BSD-License
5// shipped with this file and also available at: https://github.com/seqan/seqan3/blob/master/LICENSE.md
6// -----------------------------------------------------------------------------------------------------
7
13#pragma once
14
19
20namespace seqan3
21{
22
49template <writable_alphabet sequence_alphabet_t = aa27, writable_alphabet structure_alphabet_t = dssp9>
51 requires (!std::is_reference_v<sequence_alphabet_t>) && (!std::is_reference_v<structure_alphabet_t>)
54 public alphabet_tuple_base<structured_aa<sequence_alphabet_t, structure_alphabet_t>,
55 sequence_alphabet_t, structure_alphabet_t>
56{
57private:
60 sequence_alphabet_t, structure_alphabet_t>;
61public:
66 using sequence_alphabet_type = sequence_alphabet_t;
71 using structure_alphabet_type = structure_alphabet_t;
72
78
82 constexpr structured_aa() noexcept = default;
83 constexpr structured_aa(structured_aa const &) noexcept = default;
84 constexpr structured_aa(structured_aa &&) noexcept = default;
85 constexpr structured_aa & operator =(structured_aa const &) noexcept = default;
86 constexpr structured_aa & operator =(structured_aa &&) noexcept = default;
87 ~structured_aa() noexcept = default;
88
89 using base_type::base_type; // Inherit non-default constructors
90
91#if SEQAN3_DOXYGEN_ONLY(1)0
98 template <typename component_type>
99 constexpr structured_aa(component_type const alph) {}
100
107 template <typename indirect_component_type>
108 constexpr structured_aa(indirect_component_type const alph) {}
109
116 template <typename component_type>
117 constexpr structured_aa & operator=(component_type const alph) {}
118
125 template <typename indirect_component_type>
126 constexpr structured_aa & operator=(indirect_component_type const alph) {}
127#endif
128
133 using base_type::operator=;
135
143 constexpr structured_aa & assign_char(char_type const c) noexcept
144 {
145 seqan3::assign_char_to(c, get<0>(*this));
146 return *this;
147 }
149
157 constexpr char_type to_char() const noexcept
158 {
159 return seqan3::to_char(get<0>(*this));
160 }
162
167 static constexpr bool char_is_valid(char_type const c) noexcept
168 {
169 return char_is_valid_for<sequence_alphabet_type>(c);
170 }
171};
172
175template <typename sequence_alphabet_type, typename structure_alphabet_type>
178
179} // namespace seqan3
Provides seqan3::aa27, container aliases and string literals.
Core alphabet concept and free function/type trait wrappers.
Provides seqan3::alphabet_tuple_base.
The CRTP base for a combined alphabet that contains multiple values of different alphabets at the sam...
Definition: alphabet_tuple_base.hpp:124
A seqan3::alphabet_tuple_base that joins an aminoacid alphabet with a protein structure alphabet....
Definition: structured_aa.hpp:56
constexpr structured_aa(component_type const alph)
Construction via a value of one of the components.
Definition: structured_aa.hpp:99
sequence_alphabet_t sequence_alphabet_type
First template parameter as member type.
Definition: structured_aa.hpp:66
constexpr char_type to_char() const noexcept
Return a character. This reads the internal sequence letter.
Definition: structured_aa.hpp:157
constexpr structured_aa & operator=(component_type const alph)
Assignment via a value of one of the components.
Definition: structured_aa.hpp:117
static constexpr bool char_is_valid(char_type const c) noexcept
Validate whether a character is valid in the sequence alphabet.
Definition: structured_aa.hpp:167
structure_alphabet_t structure_alphabet_type
Second template parameter as member type.
Definition: structured_aa.hpp:71
constexpr structured_aa() noexcept=default
Defaulted.
alphabet_char_t< sequence_alphabet_type > char_type
Equals the char_type of sequence_alphabet_type.
Definition: structured_aa.hpp:77
constexpr structured_aa & operator=(indirect_component_type const alph)
Assignment via a value of a subtype that is assignable to one of the components.
Definition: structured_aa.hpp:126
constexpr structured_aa(indirect_component_type const alph)
Construction via a value of a subtype that is assignable to one of the components.
Definition: structured_aa.hpp:108
constexpr structured_aa & assign_char(char_type const c) noexcept
Assign from a nucleotide character. This modifies the internal sequence letter.
Definition: structured_aa.hpp:143
structured_aa(sequence_alphabet_type &&, structure_alphabet_type &&) -> structured_aa< std::decay_t< sequence_alphabet_type >, std::decay_t< structure_alphabet_type > >
Type deduction guide enables usage of structured_aa without specifying template args.
Provides the dssp format for protein structure.
constexpr auto assign_char_to
Assign a character to an alphabet object.
Definition: concept.hpp:526
constexpr auto to_char
Return the char representation of an alphabet object.
Definition: concept.hpp:387
decltype(seqan3::to_char(std::declval< alphabet_type const >())) alphabet_char_t
The char_type of the alphabet; defined as the return type of seqan3::to_char.
Definition: concept.hpp:399
The main SeqAn3 namespace.
Definition: cigar_operation_table.hpp:2