Antkeeper  0.0.1
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
amino-acid.hpp
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2023 Christopher J. Howard
3  *
4  * This file is part of Antkeeper source code.
5  *
6  * Antkeeper source code is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * Antkeeper source code is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Antkeeper source code. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
20 #ifndef ANTKEEPER_GENETICS_AMINO_ACID_HPP
21 #define ANTKEEPER_GENETICS_AMINO_ACID_HPP
22 
23 #include <type_traits>
24 
25 namespace genetics {
26 
28 namespace amino_acid {
29 
38 template <class Matrix>
39 typename std::remove_all_extents<Matrix>::type score(char a, char b, const Matrix& matrix);
40 
41 template <class Matrix>
42 typename std::remove_all_extents<Matrix>::type score(char a, char b, const Matrix& matrix)
43 {
44  int i = (a < 'A' || a > 'Z') ? ((a == '*') ? 26 : -1) : a - 'A';
45  int j = (b < 'A' || b > 'Z') ? ((b == '*') ? 26 : -1) : b - 'A';
46 
47  if (i < 0 || j < 0)
48  return 0;
49 
50  return matrix[i][j];
51 }
52 
53 } // namspace amino_acid
54 } // namespace genetics
55 
56 #endif // ANTKEEPER_GENETICS_AMINO_ACID_HPP
std::remove_all_extents< Matrix >::type score(char a, char b, const Matrix &matrix)
Scores two amino acids using a substitution matrix.
Definition: amino-acid.hpp:42
Genetic algorithms.
Definition: amino-acid.hpp:25