💿🐜 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.

85 lines
2.4 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_MATH_MATRIX_TYPE_HPP
  20. #define ANTKEEPER_MATH_MATRIX_TYPE_HPP
  21. #include "math/vector-type.hpp"
  22. #include <cstddef>
  23. #include <utility>
  24. namespace math {
  25. /**
  26. * An NxM matrix.
  27. *
  28. * @tparam T Matrix element type.
  29. * @tparam N Number of columns.
  30. * @tparam M Number of rows.
  31. */
  32. template <typename T, std::size_t N, std::size_t M>
  33. struct matrix
  34. {
  35. typedef T element_type;
  36. typedef vector<element_type, M> row_type;
  37. row_type columns[N];
  38. /// Identity matrix.
  39. static const matrix identity;
  40. inline constexpr row_type& operator[](std::size_t i) noexcept { return columns[i]; }
  41. inline constexpr const row_type& operator[](std::size_t i) const noexcept { return columns[i]; }
  42. };
  43. template <typename T, std::size_t I, std::size_t ... Is>
  44. constexpr vector<T, sizeof...(Is)> identity_matrix_column(const std::index_sequence<Is...>&)
  45. {
  46. return {(Is == I ? T{1} : T{0})...};
  47. }
  48. template <typename T, std::size_t ... Is>
  49. constexpr matrix<T, sizeof...(Is), sizeof...(Is)> identity_matrix_rows(const std::index_sequence<Is...>& is)
  50. {
  51. return {{identity_matrix_column<T, Is>(is)...}};
  52. }
  53. template <typename T, std::size_t N>
  54. constexpr matrix<T, N, N> identity_matrix()
  55. {
  56. return identity_matrix_rows<T>(std::make_index_sequence<N>{});
  57. }
  58. template <typename T, std::size_t N, std::size_t M>
  59. constexpr matrix<T, N, M> matrix<T, N, M>::identity = identity_matrix<T, N>();
  60. /// 2x2 matrix.
  61. template <typename T>
  62. using matrix2 = matrix<T, 2, 2>;
  63. /// 3x3 matrix.
  64. template <typename T>
  65. using matrix3 = matrix<T, 3, 3>;
  66. /// 4x4 matrix.
  67. template <typename T>
  68. using matrix4 = matrix<T, 4, 4>;
  69. } // namespace math
  70. #endif // ANTKEEPER_MATH_MATRIX_TYPE_HPP