MyraMath
trsm.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_TRSM_H
7 #define MYRAMATH_DENSE_TRSM_H
8 
14 #include <myramath/MYRAMATH_EXPORT.h>
16 
17 namespace myra {
18 
19 // Forward declarations.
20 template<class Number> class MatrixRange;
21 template<class Number> class CMatrixRange;
22 template<class Number> class CLowerMatrixRange;
23 
25 // side (input): solve from the 'L'eft (solve A*X=B) or 'R'ight (solve X*A=B)
27 // uplo (input): does A's data exist in its 'U'pper or 'L'ower triangle?
28 // op (input): any operation to apply to A? Can 'T'ranspose it, 'H'ermitian it, 'C'onjugate it, or 'N'othing
29 // A (input): a square matrix range, only specified triangle is accessed
30 // B (input/output): forcing data B, overwritten with solution data X
31 // diag (input): override A to have 'U'nit diagonal, or 'N'ot? Defaults to 'N'
32 // alpha (input): scale B prior to solution? Defaults to 1
33 MYRAMATH_EXPORT void trsm_inplace(char side, char uplo, char op, const CMatrixRange<NumberS>& A, const MatrixRange<NumberS>& B, char diag='N', NumberS alpha=1);
34 MYRAMATH_EXPORT void trsm_inplace(char side, char uplo, char op, const CMatrixRange<NumberD>& A, const MatrixRange<NumberD>& B, char diag='N', NumberD alpha=1);
35 MYRAMATH_EXPORT void trsm_inplace(char side, char uplo, char op, const CMatrixRange<NumberC>& A, const MatrixRange<NumberC>& B, char diag='N', NumberC alpha=1);
36 MYRAMATH_EXPORT void trsm_inplace(char side, char uplo, char op, const CMatrixRange<NumberZ>& A, const MatrixRange<NumberZ>& B, char diag='N', NumberZ alpha=1);
38 
40 // side (input): solve from the 'L'eft (solve A*X=B) or 'R'ight (solve X*A=B)
42 // op (input): any operation to apply to A? Can 'T'ranspose it, 'H'ermitian it, 'C'onjugate it, or 'N'othing
43 // A (input): the LowerMatrix being solved by
44 // B (input/output): forcing data B, overwritten with solution data X
45 // diag (input): override A to have 'U'nit diagonal, or 'N'ot? Defaults to 'N'
46 // alpha (input): scale B prior to solution? Defaults to 1
47 MYRAMATH_EXPORT void trsm_inplace(char side, char op, const CLowerMatrixRange<NumberS>& A, const MatrixRange<NumberS>& B, char diag='N', NumberS alpha=1);
48 MYRAMATH_EXPORT void trsm_inplace(char side, char op, const CLowerMatrixRange<NumberD>& A, const MatrixRange<NumberD>& B, char diag='N', NumberD alpha=1);
49 MYRAMATH_EXPORT void trsm_inplace(char side, char op, const CLowerMatrixRange<NumberC>& A, const MatrixRange<NumberC>& B, char diag='N', NumberC alpha=1);
50 MYRAMATH_EXPORT void trsm_inplace(char side, char op, const CLowerMatrixRange<NumberZ>& A, const MatrixRange<NumberZ>& B, char diag='N', NumberZ alpha=1);
52 
53 } // namespace
54 
55 #endif
Definition: syntax.dox:1
Various utility functions/classes related to scalar Number types.