6 #ifndef MYRAMATH_DENSE_GRAMSCHMIDT_H 7 #define MYRAMATH_DENSE_GRAMSCHMIDT_H 14 #include <myramath/MYRAMATH_EXPORT.h> 20 template<
class Number>
class Matrix;
21 template<
class Number>
class Vector;
22 template<
class Number>
class MatrixRange;
23 template<
class Number>
class VectorRange;
24 template<
class Number>
class CMatrixRange;
25 template<
class Number>
class CVectorRange;
28 MYRAMATH_EXPORT NumberS cgs_inplace(
const CVectorRange<NumberS>& q,
const VectorRange<NumberS>& v);
30 MYRAMATH_EXPORT NumberD cgs_inplace(
const CVectorRange<NumberD>& q,
const VectorRange<NumberD>& v);
31 MYRAMATH_EXPORT NumberC cgs_inplace(
const CVectorRange<NumberC>& q,
const VectorRange<NumberC>& v);
32 MYRAMATH_EXPORT NumberZ cgs_inplace(
const CVectorRange<NumberZ>& q,
const VectorRange<NumberZ>& v);
36 MYRAMATH_EXPORT Vector<NumberS> cgs_inplace(
const CMatrixRange<NumberS>& Q,
const VectorRange<NumberS>& v);
38 MYRAMATH_EXPORT Vector<NumberD> cgs_inplace(
const CMatrixRange<NumberD>& Q,
const VectorRange<NumberD>& v);
39 MYRAMATH_EXPORT Vector<NumberC> cgs_inplace(
const CMatrixRange<NumberC>& Q,
const VectorRange<NumberC>& v);
40 MYRAMATH_EXPORT Vector<NumberZ> cgs_inplace(
const CMatrixRange<NumberZ>& Q,
const VectorRange<NumberZ>& v);
44 MYRAMATH_EXPORT Matrix<NumberS> cgs_inplace(
const CMatrixRange<NumberS>& Q,
const MatrixRange<NumberS>& V);
46 MYRAMATH_EXPORT Matrix<NumberD> cgs_inplace(
const CMatrixRange<NumberD>& Q,
const MatrixRange<NumberD>& V);
47 MYRAMATH_EXPORT Matrix<NumberC> cgs_inplace(
const CMatrixRange<NumberC>& Q,
const MatrixRange<NumberC>& V);
48 MYRAMATH_EXPORT Matrix<NumberZ> cgs_inplace(
const CMatrixRange<NumberZ>& Q,
const MatrixRange<NumberZ>& V);
52 MYRAMATH_EXPORT
void mgs_inplace(
const MatrixRange<NumberS>& A,
const MatrixRange<NumberS>& R);
54 MYRAMATH_EXPORT
void mgs_inplace(
const MatrixRange<NumberD>& A,
const MatrixRange<NumberD>& R);
55 MYRAMATH_EXPORT
void mgs_inplace(
const MatrixRange<NumberC>& A,
const MatrixRange<NumberC>& R);
56 MYRAMATH_EXPORT
void mgs_inplace(
const MatrixRange<NumberZ>& A,
const MatrixRange<NumberZ>& R);
60 MYRAMATH_EXPORT Matrix<NumberS> mgs_inplace(
const MatrixRange<NumberS>& A);
62 MYRAMATH_EXPORT Matrix<NumberD> mgs_inplace(
const MatrixRange<NumberD>& A);
63 MYRAMATH_EXPORT Matrix<NumberC> mgs_inplace(
const MatrixRange<NumberC>& A);
64 MYRAMATH_EXPORT Matrix<NumberZ> mgs_inplace(
const MatrixRange<NumberZ>& A);
68 MYRAMATH_EXPORT std::pair< Matrix<NumberS>, Matrix<NumberS> > mgs(
const CMatrixRange<NumberS>& A);
70 MYRAMATH_EXPORT std::pair< Matrix<NumberD>, Matrix<NumberD> > mgs(
const CMatrixRange<NumberD>& A);
71 MYRAMATH_EXPORT std::pair< Matrix<NumberC>, Matrix<NumberC> > mgs(
const CMatrixRange<NumberC>& A);
72 MYRAMATH_EXPORT std::pair< Matrix<NumberZ>, Matrix<NumberZ> > mgs(
const CMatrixRange<NumberZ>& A);
Various utility functions/classes related to scalar Number types.