MyraMath
gramschmidt.h
Go to the documentation of this file.
1 // ========================================================================= //
2 // This file is part of MyraMath, copyright (c) 2014-2019 by Ryan A Chilton //
3 // and distributed by MyraCore, LLC. See LICENSE.txt for license terms. //
4 // ========================================================================= //
5 
6 #ifndef MYRAMATH_DENSE_GRAMSCHMIDT_H
7 #define MYRAMATH_DENSE_GRAMSCHMIDT_H
8 
14 #include <myramath/MYRAMATH_EXPORT.h>
16 
17 namespace myra {
18 
19 // Forward declarations.
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;
26 
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);
34 
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);
42 
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);
50 
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);
58 
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);
66 
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);
74 
75 } // namespace
76 
77 #endif
Definition: syntax.dox:1
Various utility functions/classes related to scalar Number types.