/*
* Copyright (C) 2021 Christopher J. Howard
*
* This file is part of Antkeeper source code.
*
* Antkeeper source code is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Antkeeper source code is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Antkeeper source code. If not, see .
*/
#ifndef ANTKEEPER_MATH_MATRIX_TYPE_HPP
#define ANTKEEPER_MATH_MATRIX_TYPE_HPP
#include "math/vector-type.hpp"
#include
#include
namespace math {
/**
* An NxM matrix.
*
* @tparam T Matrix element type.
* @tparam N Number of columns.
* @tparam M Number of rows.
*/
template
struct matrix
{
typedef T element_type;
typedef vector row_type;
row_type columns[N];
/// Identity matrix.
static const matrix identity;
inline constexpr row_type& operator[](std::size_t i) noexcept { return columns[i]; }
inline constexpr const row_type& operator[](std::size_t i) const noexcept { return columns[i]; }
};
template
constexpr vector identity_matrix_column(const std::index_sequence&)
{
return {(Is == I ? T{1} : T{0})...};
}
template
constexpr matrix identity_matrix_rows(const std::index_sequence& is)
{
return {{identity_matrix_column(is)...}};
}
template
constexpr matrix identity_matrix()
{
return identity_matrix_rows(std::make_index_sequence{});
}
template
constexpr matrix matrix::identity = identity_matrix();
/// 2x2 matrix.
template
using matrix2 = matrix;
/// 3x3 matrix.
template
using matrix3 = matrix;
/// 4x4 matrix.
template
using matrix4 = matrix;
} // namespace math
#endif // ANTKEEPER_MATH_MATRIX_TYPE_HPP