SeqAn3  3.0.3
The Modern C++ library for sequence analysis.
phred_base.hpp
Go to the documentation of this file.
1 // -----------------------------------------------------------------------------------------------------
2 // Copyright (c) 2006-2020, Knut Reinert & Freie Universität Berlin
3 // Copyright (c) 2016-2020, 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 
18 
19 namespace seqan3
20 {
21 
29 template <typename derived_type, size_t size>
30 class phred_base : public alphabet_base<derived_type, size, char>
31 {
32 public:
40  using phred_type = int8_t;
42 
43 private:
46 
48  friend base_t;
49 
53  constexpr phred_base() noexcept = default;
54  constexpr phred_base(phred_base const &) noexcept = default;
55  constexpr phred_base(phred_base &&) noexcept = default;
56  constexpr phred_base & operator=(phred_base const &) noexcept = default;
57  constexpr phred_base & operator=(phred_base &&) noexcept = default;
58  ~phred_base() noexcept = default;
59 
64  constexpr phred_base(phred_type const p) noexcept
65  {
66  static_cast<derived_type *>(this)->assign_phred(p);
67  }
69 
71  friend derived_type;
72 
73 public:
74  // Import from base type:
76  using base_t::to_rank;
77  using base_t::assign_rank;
78  using typename base_t::char_type;
79  using typename base_t::rank_type;
80 
84  // This constructor needs to be public, because constructor templates are not inherited otherwise
89  template <typename other_qual_type>
91  requires (!std::same_as<phred_base, other_qual_type>) &&
92  (!std::same_as<derived_type, other_qual_type>) &&
95  explicit constexpr phred_base(other_qual_type const & other) noexcept
96  {
97  assign_phred_to(seqan3::to_phred(other), static_cast<derived_type &>(*this));
98  }
100 
110  constexpr phred_type to_phred() const noexcept
111  {
112  return rank_to_phred[to_rank()];
113  }
115 
135  constexpr derived_type & assign_phred(phred_type const p) noexcept
136  {
137  return assign_rank(phred_to_rank[static_cast<rank_type>(p)]);
138  }
140 
141 private:
144  {
145  [] () constexpr
146  {
148 
149  for (int64_t i = std::numeric_limits<phred_type>::lowest(); i <= std::numeric_limits<phred_type>::max(); ++i)
150  {
151  if (i < derived_type::offset_phred) // map too-small to smallest possible
152  ret[static_cast<rank_type>(i)] = 0;
153  else if (i >= derived_type::offset_phred + alphabet_size) // map too-large to highest possible
154  ret[static_cast<rank_type>(i)] = alphabet_size - 1;
155  else // map valid range to identity
156  ret[static_cast<rank_type>(i)] = i - derived_type::offset_phred;
157  }
158  return ret;
159  }()
160  };
161 
164  {
165  [] () constexpr
166  {
168 
169  for (size_t i = 0; i < alphabet_size; ++i)
170  ret[i] = i + derived_type::offset_phred;
171 
172  return ret;
173  }()
174  };
175 
177  static constexpr rank_type char_to_rank(char_type const chr)
178  {
179  int64_t difference = static_cast<int64_t>(chr) - static_cast<int64_t>(derived_type::offset_char);
180  return std::clamp<int64_t>(difference, 0, alphabet_size - 1);
181  }
182 
184  static constexpr char_type rank_to_char(rank_type const rank)
185  {
186  return rank + derived_type::offset_char;
187  }
188 };
189 
190 } // namespace seqan3
Provides seqan3::detail::convert_through_char_representation.
Quality alphabet concept.
Provides seqan3::alphabet_base.
A CRTP-base that makes defining a custom alphabet easier.
Definition: alphabet_base.hpp:81
constexpr rank_type to_rank() const noexcept
Return the letter's numeric value (rank in the alphabet).
Definition: alphabet_base.hpp:185
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
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
constexpr derived_type & assign_rank(rank_type const c) noexcept
Assign from a numeric value.
Definition: alphabet_base.hpp:264
std::conditional_t< std::same_as< char, void >, char, char > char_type
The char representation; conditional needed to make semi alphabet definitions legal.
Definition: alphabet_base.hpp:96
rank_type rank
The value of the alphabet letter is stored as the rank.
Definition: alphabet_base.hpp:338
A CRTP-base that refines seqan3::alphabet_base and is used by the quality alphabets.
Definition: phred_base.hpp:31
constexpr phred_type to_phred() const noexcept
Return the alphabet's value in Phred score representation.
Definition: phred_base.hpp:110
friend derived_type
Befriend the derived_type so it can instantiate.
Definition: phred_base.hpp:71
static constexpr std::array< phred_type, alphabet_size > rank_to_phred
Rank to phred conversion table.
Definition: phred_base.hpp:164
constexpr derived_type & assign_phred(phred_type const p) noexcept
Assign from the numeric Phred score value.
Definition: phred_base.hpp:135
static constexpr char_type rank_to_char(rank_type const rank)
Returns the character representation of rank.
Definition: phred_base.hpp:184
static constexpr rank_type char_to_rank(char_type const chr)
Returns the rank representation of character.
Definition: phred_base.hpp:177
constexpr phred_base() noexcept=default
Defaulted.
constexpr phred_base(other_qual_type const &other) noexcept
Allow explicit construction from any other quality type by means of the Phred score representation.
Definition: phred_base.hpp:95
friend base_t
Befriend the base type so it can access char_to_rank and rank_to_char.
Definition: phred_base.hpp:48
static constexpr std::array< rank_type, 256 > phred_to_rank
Phred to rank conversion table.
Definition: phred_base.hpp:144
int8_t phred_type
The integer representation of the quality score.
Definition: phred_base.hpp:40
constexpr auto to_phred
The public getter function for the Phred representation of a quality score.
Definition: concept.hpp:100
constexpr auto assign_phred_to
Assign a Phred score to a quality alphabet object.
Definition: concept.hpp:231
A concept that indicates whether an alphabet represents quality scores.
The main SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29