Я пытаюсь создать матричный класс фиксированного размера. Намерение состоит в том, чтобы заставить его наследовать или использовать std::array
из std::array
:
template <size_t Rows, size_t Columns, class T=double>
struct Matrix : public std::array<std::array<T, Columns>, Rows> {
};
Я хотел бы предоставить инициализатор, который может автоматически определять размер, например std::array
может в C ++ 17 (который я использую). Я также хорошо отношусь к использованию функции для создания Matrix
вместо использования вывода аргументов шаблона класса.
// What I want, but does not work:
Matrix matrix {{1., 2.},
{3., 4.}};
// Or:
auto matrix = MakeMatrix ({1., 2.},
{3., 4.});
Мне не удалось реализовать ни один из этих вариантов. Вместо этого работает только следующее:
// Requires specifying the size and repeating `std::array`, both undesired
Matrix<2,2> mat {
std::array{1., 2.},
std::array{3., 4.}
};
// OR this, which requires specifying the size and is generally confusing
Matrix<2,2> mat2 {1., 2.,
3., 4.};
Я пробовал использовать вариативные c шаблоны, но это тоже не понравилось компилятору:
template<class... Args>
auto MakeMatrix (Args... args) {
return Matrix{ std::array {args} ... };
}
// This causes compiler error:
// error: no matching function for call to 'MakeMatrix'
// candidate function [with Args = <>] not viable: requires 0 arguments, but 2 were provided
auto matrix = MakeMatrix ({1., 2.},
{3., 4.});
// This causes compiler error
// error: no viable constructor or deduction guide for deduction of template arguments of 'Matrix'
// note: in instantiation of function template specialization 'MakeMatrix<std::__1::array<double, 2>, std::__1::array<double, 2> >'
// note: note: candidate function template not viable: requires 0 arguments, but 2 were provided
auto matrix = MakeMatrix (std::array {1., 2.},
std::array {3., 4.});
Я также подумал об использовании std::initializer_list<std::initializer_list<T>>
, однако они не поддерживают фиксированный размер, насколько я могу судить, и я хочу, чтобы размер определялся во время компиляции.
Любые мысли о том, как это сделать, или это просто невозможно с текущим C ++ механика?