MyraMath
hemm.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_HEMM_H
7 #define MYRAMATH_DENSE_HEMM_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 MatrixRange;
22 template<class Number> class CMatrixRange;
23 template<class Number> class LowerMatrixRange;
24 template<class Number> class CLowerMatrixRange;
25 
27 MYRAMATH_EXPORT void hemm_inplace(char side, char uplo, const MatrixRange<NumberS>& C, const CMatrixRange<NumberS>& A, const CMatrixRange<NumberS>& B, NumberS alpha, NumberS beta);
29 MYRAMATH_EXPORT void hemm_inplace(char side, char uplo, const MatrixRange<NumberD>& C, const CMatrixRange<NumberD>& A, const CMatrixRange<NumberD>& B, NumberD alpha, NumberD beta);
30 MYRAMATH_EXPORT void hemm_inplace(char side, char uplo, const MatrixRange<NumberC>& C, const CMatrixRange<NumberC>& A, const CMatrixRange<NumberC>& B, NumberC alpha, NumberC beta);
31 MYRAMATH_EXPORT void hemm_inplace(char side, char uplo, const MatrixRange<NumberZ>& C, const CMatrixRange<NumberZ>& A, const CMatrixRange<NumberZ>& B, NumberZ alpha, NumberZ beta);
33 
35 MYRAMATH_EXPORT Matrix<NumberS> hemm(char side, char uplo, const CMatrixRange<NumberS>& A, const CMatrixRange<NumberS>& B, NumberS alpha = 1);
37 MYRAMATH_EXPORT Matrix<NumberD> hemm(char side, char uplo, const CMatrixRange<NumberD>& A, const CMatrixRange<NumberD>& B, NumberD alpha = 1);
38 MYRAMATH_EXPORT Matrix<NumberC> hemm(char side, char uplo, const CMatrixRange<NumberC>& A, const CMatrixRange<NumberC>& B, NumberC alpha = 1);
39 MYRAMATH_EXPORT Matrix<NumberZ> hemm(char side, char uplo, const CMatrixRange<NumberZ>& A, const CMatrixRange<NumberZ>& B, NumberZ alpha = 1);
41 
43 MYRAMATH_EXPORT void hemm_inplace(char side, const MatrixRange<NumberS>& C, const CLowerMatrixRange<NumberS>& A, const CMatrixRange<NumberS>& B, NumberS alpha, NumberS beta);
45 MYRAMATH_EXPORT void hemm_inplace(char side, const MatrixRange<NumberD>& C, const CLowerMatrixRange<NumberD>& A, const CMatrixRange<NumberD>& B, NumberD alpha, NumberD beta);
46 // Note the non-const reference A, the complex routines modify A but restore it before returning. They are not thread-safe.
47 MYRAMATH_EXPORT void hemm_inplace(char side, const MatrixRange<NumberC>& C, const LowerMatrixRange<NumberC>& A, const CMatrixRange<NumberC>& B, NumberC alpha, NumberC beta);
48 MYRAMATH_EXPORT void hemm_inplace(char side, const MatrixRange<NumberZ>& C, const LowerMatrixRange<NumberZ>& A, const CMatrixRange<NumberZ>& B, NumberZ alpha, NumberZ beta);
50 
52 MYRAMATH_EXPORT Matrix<NumberS> hemm(char side, const CLowerMatrixRange<NumberS>& A, const CMatrixRange<NumberS>& B, NumberS alpha = 1);
54 MYRAMATH_EXPORT Matrix<NumberD> hemm(char side, const CLowerMatrixRange<NumberD>& A, const CMatrixRange<NumberD>& B, NumberD alpha = 1);
55 // Note the non-const reference A, the complex routines modify A but restore it before returning. They are not thread-safe.
56 MYRAMATH_EXPORT Matrix<NumberC> hemm(char side, const LowerMatrixRange<NumberC>& A, const CMatrixRange<NumberC>& B, NumberC alpha = 1);
57 MYRAMATH_EXPORT Matrix<NumberZ> hemm(char side, const LowerMatrixRange<NumberZ>& A, const CMatrixRange<NumberZ>& B, NumberZ alpha = 1);
59 
60 } // namespace
61 
62 #endif
Definition: syntax.dox:1
Various utility functions/classes related to scalar Number types.