6 #ifndef MYRAMATH_DENSE_DIAGCAT_H 7 #define MYRAMATH_DENSE_DIAGCAT_H 14 #include <myramath/MYRAMATH_EXPORT.h> 20 template<
class T>
class Array1;
21 template<
class Number>
class Matrix;
22 template<
class Number>
class CMatrixRange;
23 template<
class Number>
class DiagonalMatrix;
24 template<
class Number>
class CDiagonalMatrixRange;
27 MYRAMATH_EXPORT Matrix<NumberS> diagcat (
const CMatrixRange<NumberS>& A,
const CMatrixRange<NumberS>& B);
29 MYRAMATH_EXPORT Matrix<NumberD> diagcat (
const CMatrixRange<NumberD>& A,
const CMatrixRange<NumberD>& B);
30 MYRAMATH_EXPORT Matrix<NumberC> diagcat (
const CMatrixRange<NumberC>& A,
const CMatrixRange<NumberC>& B);
31 MYRAMATH_EXPORT Matrix<NumberZ> diagcat (
const CMatrixRange<NumberZ>& A,
const CMatrixRange<NumberZ>& B);
35 MYRAMATH_EXPORT DiagonalMatrix<NumberS> diagcat (
const CDiagonalMatrixRange<NumberS>& A,
const CDiagonalMatrixRange<NumberS>& B);
37 MYRAMATH_EXPORT DiagonalMatrix<NumberD> diagcat (
const CDiagonalMatrixRange<NumberD>& A,
const CDiagonalMatrixRange<NumberD>& B);
38 MYRAMATH_EXPORT DiagonalMatrix<NumberC> diagcat (
const CDiagonalMatrixRange<NumberC>& A,
const CDiagonalMatrixRange<NumberC>& B);
39 MYRAMATH_EXPORT DiagonalMatrix<NumberZ> diagcat (
const CDiagonalMatrixRange<NumberZ>& A,
const CDiagonalMatrixRange<NumberZ>& B);
43 MYRAMATH_EXPORT Matrix<NumberS> diagcat(
const Array1<CMatrixRange<NumberS> >& ranges);
45 MYRAMATH_EXPORT Matrix<NumberD> diagcat(
const Array1<CMatrixRange<NumberD> >& ranges);
46 MYRAMATH_EXPORT Matrix<NumberC> diagcat(
const Array1<CMatrixRange<NumberC> >& ranges);
47 MYRAMATH_EXPORT Matrix<NumberZ> diagcat(
const Array1<CMatrixRange<NumberZ> >& ranges);
51 MYRAMATH_EXPORT DiagonalMatrix<NumberS> diagcat(
const Array1<CDiagonalMatrixRange<NumberS> >& ranges);
53 MYRAMATH_EXPORT DiagonalMatrix<NumberD> diagcat(
const Array1<CDiagonalMatrixRange<NumberD> >& ranges);
54 MYRAMATH_EXPORT DiagonalMatrix<NumberC> diagcat(
const Array1<CDiagonalMatrixRange<NumberC> >& ranges);
55 MYRAMATH_EXPORT DiagonalMatrix<NumberZ> diagcat(
const Array1<CDiagonalMatrixRange<NumberZ> >& ranges);
Various utility functions/classes related to scalar Number types.