MyraMath
trmm.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_TRMM_H
7 #define MYRAMATH_DENSE_TRMM_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): multiply from the 'L'eft (multiply B=A*X) or 'R'ight (multiply B=X*A)
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? e.g. 'T'ranspose it, 'H'ermitian it, or 'N'othing
29 // A (input): a square matrix range, only specified triangle is accessed
30 // X (input/output): original data X, overwritten with B
31 // diag (input): override A to have 'U'nit diagonal, or 'N'ot? Defaults to 'N'
32 // alpha (input): multiplier applied to A, defaults to 1
33 MYRAMATH_EXPORT void trmm_inplace(char side, char uplo, char op, const CMatrixRange<NumberS>& A, const MatrixRange<NumberS>& X, char diag = 'N', NumberS alpha = 1);
34 MYRAMATH_EXPORT void trmm_inplace(char side, char uplo, char op, const CMatrixRange<NumberD>& A, const MatrixRange<NumberD>& X, char diag = 'N', NumberD alpha = 1);
35 MYRAMATH_EXPORT void trmm_inplace(char side, char uplo, char op, const CMatrixRange<NumberC>& A, const MatrixRange<NumberC>& X, char diag = 'N', NumberC alpha = 1);
36 MYRAMATH_EXPORT void trmm_inplace(char side, char uplo, char op, const CMatrixRange<NumberZ>& A, const MatrixRange<NumberZ>& X, char diag = 'N', NumberZ alpha = 1);
38 
40 // side (input): multiply from the 'L'eft (multiply B=A*X) or 'R'ight (multiply B=X*A)
42 // op (input): any operation to apply to A? e.g. 'T'ranspose it, 'H'ermitian it, or 'N'othing.
43 // A (input): the LowerMatrix being multipled by
44 // X (input/output): original data X, overwritten with B
45 // diag (input): override A to have 'U'nit diagonal, or 'N'ot? Defaults to 'N'
46 // alpha (input): multiplier applied to A, defaults to 1
47 MYRAMATH_EXPORT void trmm_inplace (char side, char op, const CLowerMatrixRange<NumberS>& A, const MatrixRange<NumberS>& X, char diag = 'N', NumberS alpha = 1);
48 MYRAMATH_EXPORT void trmm_inplace (char side, char op, const CLowerMatrixRange<NumberD>& A, const MatrixRange<NumberD>& X, char diag = 'N', NumberD alpha = 1);
49 MYRAMATH_EXPORT void trmm_inplace (char side, char op, const CLowerMatrixRange<NumberC>& A, const MatrixRange<NumberC>& X, char diag = 'N', NumberC alpha = 1);
50 MYRAMATH_EXPORT void trmm_inplace (char side, char op, const CLowerMatrixRange<NumberZ>& A, const MatrixRange<NumberZ>& X, 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.