💿🐜 Antkeeper source code https://antkeeper.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

107 lines
7.7 KiB

  1. /*
  2. * Copyright (C) 2021 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. #ifndef ANTKEEPER_GENETICS_MATRIX_HPP
  20. #define ANTKEEPER_GENETICS_MATRIX_HPP
  21. namespace genetics {
  22. /// Substitution matrix constants.
  23. namespace matrix {
  24. /**
  25. * BLOSUM62 substitution matrix.
  26. *
  27. * @see ftp://ftp.ncbi.nih.gov/blast/matrices/
  28. */
  29. template <class T>
  30. constexpr T blosum62[27][27] =
  31. {
  32. // A B C D E F G H I J K L M N O P Q R S T U V W X Y Z *
  33. { 4, -2, 0, -2, -1, -2, 0, -2, -1, 0, -1, -1, -1, -2, 0, -1, -1, -1, 1, 0, 0, 0, -3, 0, -2, -1, -4 }, // A
  34. { -2, 4, -3, 4, 1, -3, -1, 0, -3, 0, 0, -4, -3, 3, 0, -2, 0, -1, 0, -1, 0, -3, -4, -1, -3, 1, -4 }, // B
  35. { 0, -3, 9, -3, -4, -2, -3, -3, -1, 0, -3, -1, -1, -3, 0, -3, -3, -3, -1, -1, 0, -1, -2, -2, -2, -3, -4 }, // C
  36. { -2, 4, -3, 6, 2, -3, -1, -1, -3, 0, -1, -4, -3, 1, 0, -1, 0, -2, 0, -1, 0, -3, -4, -1, -3, 1, -4 }, // D
  37. { -1, 1, -4, 2, 5, -3, -2, 0, -3, 0, 1, -3, -2, 0, 0, -1, 2, 0, 0, -1, 0, -2, -3, -1, -2, 4, -4 }, // E
  38. { -2, -3, -2, -3, -3, 6, -3, -1, 0, 0, -3, 0, 0, -3, 0, -4, -3, -3, -2, -2, 0, -1, 1, -1, 3, -3, -4 }, // F
  39. { 0, -1, -3, -1, -2, -3, 6, -2, -4, 0, -2, -4, -3, 0, 0, -2, -2, -2, 0, -2, 0, -3, -2, -1, -3, -2, -4 }, // G
  40. { -2, 0, -3, -1, 0, -1, -2, 8, -3, 0, -1, -3, -2, 1, 0, -2, 0, 0, -1, -2, 0, -3, -2, -1, 2, 0, -4 }, // H
  41. { -1, -3, -1, -3, -3, 0, -4, -3, 4, 0, -3, 2, 1, -3, 0, -3, -3, -3, -2, -1, 0, 3, -3, -1, -1, -3, -4 }, // I
  42. { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, // J
  43. { -1, 0, -3, -1, 1, -3, -2, -1, -3, 0, 5, -2, -1, 0, 0, -1, 1, 2, 0, -1, 0, -2, -3, -1, -2, 1, -4 }, // K
  44. { -1, -4, -1, -4, -3, 0, -4, -3, 2, 0, -2, 4, 2, -3, 0, -3, -2, -2, -2, -1, 0, 1, -2, -1, -1, -3, -4 }, // L
  45. { -1, -3, -1, -3, -2, 0, -3, -2, 1, 0, -1, 2, 5, -2, 0, -2, 0, -1, -1, -1, 0, 1, -1, -1, -1, -1, -4 }, // M
  46. { -2, 3, -3, 1, 0, -3, 0, 1, -3, 0, 0, -3, -2, 6, 0, -2, 0, 0, 1, 0, 0, -3, -4, -1, -2, 0, -4 }, // N
  47. { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, // O
  48. { -1, -2, -3, -1, -1, -4, -2, -2, -3, 0, -1, -3, -2, -2, 0, 7, -1, -2, -1, -1, 0, -2, -4, -2, -3, -1, -4 }, // P
  49. { -1, 0, -3, 0, 2, -3, -2, 0, -3, 0, 1, -2, 0, 0, 0, -1, 5, 1, 0, -1, 0, -2, -2, -1, -1, 3, -4 }, // Q
  50. { -1, -1, -3, -2, 0, -3, -2, 0, -3, 0, 2, -2, -1, 0, 0, -2, 1, 5, -1, -1, 0, -3, -3, -1, -2, 0, -4 }, // R
  51. { 1, 0, -1, 0, 0, -2, 0, -1, -2, 0, 0, -2, -1, 1, 0, -1, 0, -1, 4, 1, 0, -2, -3, 0, -2, 0, -4 }, // S
  52. { 0, -1, -1, -1, -1, -2, -2, -2, -1, 0, -1, -1, -1, 0, 0, -1, -1, -1, 1, 5, 0, 0, -2, 0, -2, -1, -4 }, // T
  53. { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, // U
  54. { 0, -3, -1, -3, -2, -1, -3, -3, 3, 0, -2, 1, 1, -3, 0, -2, -2, -3, -2, 0, 0, 4, -3, -1, -1, -2, -4 }, // V
  55. { -3, -4, -2, -4, -3, 1, -2, -2, -3, 0, -3, -2, -1, -4, 0, -4, -2, -3, -3, -2, 0, -3, 11, -2, 2, -3, -4 }, // W
  56. { 0, -1, -2, -1, -1, -1, -1, -1, -1, 0, -1, -1, -1, -1, 0, -2, -1, -1, 0, 0, 0, -1, -2, -1, -1, -1, -4 }, // X
  57. { -2, -3, -2, -3, -2, 3, -3, 2, -1, 0, -2, -1, -1, -2, 0, -3, -1, -2, -2, -2, 0, -1, 2, -1, 7, -2, -4 }, // Y
  58. { -1, 1, -3, 1, 4, -3, -2, 0, -3, 0, 1, -3, -1, 0, 0, -1, 3, 0, 0, -1, 0, -2, -3, -1, -2, 4, -4 }, // Z
  59. { -4, -4, -4, -4, -4, -4, -4, -4, -4, 0, -4, -4, -4, -4, 0, -4, -4, -4, -4, -4, 0, -4, -4, -4, -4, -4, 1 } // *
  60. };
  61. /**
  62. * BLOSUM80 substitution matrix.
  63. *
  64. * @see ftp://ftp.ncbi.nih.gov/blast/matrices/
  65. */
  66. template <class T>
  67. constexpr T blosum80[27][27] =
  68. {
  69. // A B C D E F G H I J K L M N O P Q R S T U V W X Y Z *
  70. { 7, -3, -1, -3, -2, -4, 0, -3, -3, 0, -1, -3, -2, -3, 0, -1, -2, -3, 2, 0, 0, -1, -5, -1, -4, -2, -8 }, // A
  71. { -3, 6, -6, 6, 1, -6, -2, -1, -6, 0, -1, -7, -5, 5, 0, -4, -1, -2, 0, -1, 0, -6, -8, -3, -5, 0, -8 }, // B
  72. { -1, -6, 13, -7, -7, -4, -6, -7, -2, 0, -6, -3, -3, -5, 0, -6, -5, -6, -2, -2, 0, -2, -5, -4, -5, -7, -8 }, // C
  73. { -3, 6, -7, 10, 2, -6, -3, -2, -7, 0, -2, -7, -6, 2, 0, -3, -1, -3, -1, -2, 0, -6, -8, -3, -6, 1, -8 }, // D
  74. { -2, 1, -7, 2, 8, -6, -4, 0, -6, 0, 1, -6, -4, -1, 0, -2, 3, -1, -1, -2, 0, -4, -6, -2, -5, 6, -8 }, // E
  75. { -4, -6, -4, -6, -6, 10, -6, -2, -1, 0, -5, 0, 0, -6, 0, -6, -5, -5, -4, -4, 0, -2, 0, -3, 4, -6, -8 }, // F
  76. { 0, -2, -6, -3, -4, -6, 9, -4, -7, 0, -3, -7, -5, -1, 0, -5, -4, -4, -1, -3, 0, -6, -6, -3, -6, -4, -8 }, // G
  77. { -3, -1, -7, -2, 0, -2, -4, 12, -6, 0, -1, -5, -4, 1, 0, -4, 1, 0, -2, -3, 0, -5, -4, -2, 3, 0, -8 }, // H
  78. { -3, -6, -2, -7, -6, -1, -7, -6, 7, 0, -5, 2, 2, -6, 0, -5, -5, -5, -4, -2, 0, 4, -5, -2, -3, -6, -8 }, // I
  79. { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, // J
  80. { -1, -1, -6, -2, 1, -5, -3, -1, -5, 0, 8, -4, -3, 0, 0, -2, 2, 3, -1, -1, 0, -4, -6, -2, -4, 1, -8 }, // K
  81. { -3, -7, -3, -7, -6, 0, -7, -5, 2, 0, -4, 6, 3, -6, 0, -5, -4, -4, -4, -3, 0, 1, -4, -2, -2, -5, -8 }, // L
  82. { -2, -5, -3, -6, -4, 0, -5, -4, 2, 0, -3, 3, 9, -4, 0, -4, -1, -3, -3, -1, 0, 1, -3, -2, -3, -3, -8 }, // M
  83. { -3, 5, -5, 2, -1, -6, -1, 1, -6, 0, 0, -6, -4, 9, 0, -4, 0, -1, 1, 0, 0, -5, -7, -2, -4, -1, -8 }, // N
  84. { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, // O
  85. { -1, -4, -6, -3, -2, -6, -5, -4, -5, 0, -2, -5, -4, -4, 0, 12, -3, -3, -2, -3, 0, -4, -7, -3, -6, -2, -8 }, // P
  86. { -2, -1, -5, -1, 3, -5, -4, 1, -5, 0, 2, -4, -1, 0, 0, -3, 9, 1, -1, -1, 0, -4, -4, -2, -3, 5, -8 }, // Q
  87. { -3, -2, -6, -3, -1, -5, -4, 0, -5, 0, 3, -4, -3, -1, 0, -3, 1, 9, -2, -2, 0, -4, -5, -2, -4, 0, -8 }, // R
  88. { 2, 0, -2, -1, -1, -4, -1, -2, -4, 0, -1, -4, -3, 1, 0, -2, -1, -2, 7, 2, 0, -3, -6, -1, -3, -1, -8 }, // S
  89. { 0, -1, -2, -2, -2, -4, -3, -3, -2, 0, -1, -3, -1, 0, 0, -3, -1, -2, 2, 8, 0, 0, -5, -1, -3, -2, -8 }, // T
  90. { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, // U
  91. { -1, -6, -2, -6, -4, -2, -6, -5, 4, 0, -4, 1, 1, -5, 0, -4, -4, -4, -3, 0, 0, 7, -5, -2, -3, -4, -8 }, // V
  92. { -5, -8, -5, -8, -6, 0, -6, -4, -5, 0, -6, -4, -3, -7, 0, -7, -4, -5, -6, -5, 0, -5, 16, -5, 3, -5, -8 }, // W
  93. { -1, -3, -4, -3, -2, -3, -3, -2, -2, 0, -2, -2, -2, -2, 0, -3, -2, -2, -1, -1, 0, -2, -5, -2, -3, -1, -8 }, // X
  94. { -4, -5, -5, -6, -5, 4, -6, 3, -3, 0, -4, -2, -3, -4, 0, -6, -3, -4, -3, -3, 0, -3, 3, -3, 11, -4, -8 }, // Y
  95. { -2, 0, -7, 1, 6, -6, -4, 0, -6, 0, 1, -5, -3, -1, 0, -2, 5, 0, -1, -2, 0, -4, -5, -1, -4, 6, -8 }, // Z
  96. { -8, -8, -8, -8, -8, -8, -8, -8, -8, 0, -8, -8, -8, -8, 0, -8, -8, -8, -8, -8, 0, -8, -8, -8, -8, -8, 1 } // *
  97. };
  98. } // namspace matrix
  99. } // namespace genetics
  100. #endif // ANTKEEPER_GENETICS_MATRIX_HPP