MyraMath
gemv.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_GEMV_H
7 #define MYRAMATH_DENSE_GEMV_H
8 
14 #include <myramath/MYRAMATH_EXPORT.h>
16 
17 namespace myra {
18 
19 template<class Number> class CMatrixRange;
20 template<class Number> class CVectorRange;
21 template<class Number> class VectorRange;
22 template<class Number> class Vector;
23 
24 // --------------------------------- Multiplies A*b, for Matrix A and column Vector b
25 
27 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberS>& c, const CMatrixRange<NumberS>& A, char op, const CVectorRange<NumberS>& b, NumberS alpha, NumberS beta);
29 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberD>& c, const CMatrixRange<NumberD>& A, char op, const CVectorRange<NumberD>& b, NumberD alpha, NumberD beta);
30 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberC>& c, const CMatrixRange<NumberC>& A, char op, const CVectorRange<NumberC>& b, NumberC alpha, NumberC beta);
31 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberZ>& c, const CMatrixRange<NumberZ>& A, char op, const CVectorRange<NumberZ>& b, NumberZ alpha, NumberZ beta);
33 
35 MYRAMATH_EXPORT Vector<NumberS> gemv(const CMatrixRange<NumberS>& A, char op, const CVectorRange<NumberS>& b, NumberS alpha = 1);
37 MYRAMATH_EXPORT Vector<NumberD> gemv(const CMatrixRange<NumberD>& A, char op, const CVectorRange<NumberD>& b, NumberD alpha = 1);
38 MYRAMATH_EXPORT Vector<NumberC> gemv(const CMatrixRange<NumberC>& A, char op, const CVectorRange<NumberC>& b, NumberC alpha = 1);
39 MYRAMATH_EXPORT Vector<NumberZ> gemv(const CMatrixRange<NumberZ>& A, char op, const CVectorRange<NumberZ>& b, NumberZ alpha = 1);
41 
43 MYRAMATH_EXPORT Vector<NumberS> gemv(const CMatrixRange<NumberS>& A, const CVectorRange<NumberS>& b, NumberS alpha = 1);
45 MYRAMATH_EXPORT Vector<NumberD> gemv(const CMatrixRange<NumberD>& A, const CVectorRange<NumberD>& b, NumberD alpha = 1);
46 MYRAMATH_EXPORT Vector<NumberC> gemv(const CMatrixRange<NumberC>& A, const CVectorRange<NumberC>& b, NumberC alpha = 1);
47 MYRAMATH_EXPORT Vector<NumberZ> gemv(const CMatrixRange<NumberZ>& A, const CVectorRange<NumberZ>& b, NumberZ alpha = 1);
49 
51 MYRAMATH_EXPORT Vector<NumberS> operator * (const CMatrixRange<NumberS>& A, const CVectorRange<NumberS>& b);
53 MYRAMATH_EXPORT Vector<NumberD> operator * (const CMatrixRange<NumberD>& A, const CVectorRange<NumberD>& b);
54 MYRAMATH_EXPORT Vector<NumberC> operator * (const CMatrixRange<NumberC>& A, const CVectorRange<NumberC>& b);
55 MYRAMATH_EXPORT Vector<NumberZ> operator * (const CMatrixRange<NumberZ>& A, const CVectorRange<NumberZ>& b);
57 
58 // --------------------------------- Multiplies a*B, for row Vector a and Matrix B
59 
61 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberS>& c, const CVectorRange<NumberS>& a, const CMatrixRange<NumberS>& B, char op, NumberS alpha, NumberS beta);
63 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberD>& c, const CVectorRange<NumberD>& a, const CMatrixRange<NumberD>& B, char op, NumberD alpha, NumberD beta);
64 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberC>& c, const CVectorRange<NumberC>& a, const CMatrixRange<NumberC>& B, char op, NumberC alpha, NumberC beta);
65 MYRAMATH_EXPORT void gemv_inplace(const VectorRange<NumberZ>& c, const CVectorRange<NumberZ>& a, const CMatrixRange<NumberZ>& B, char op, NumberZ alpha, NumberZ beta);
67 
69 MYRAMATH_EXPORT Vector<NumberS> gemv(const CVectorRange<NumberS>& a, const CMatrixRange<NumberS>& B, char op, NumberS alpha = 1);
71 MYRAMATH_EXPORT Vector<NumberD> gemv(const CVectorRange<NumberD>& a, const CMatrixRange<NumberD>& B, char op, NumberD alpha = 1);
72 MYRAMATH_EXPORT Vector<NumberC> gemv(const CVectorRange<NumberC>& a, const CMatrixRange<NumberC>& B, char op, NumberC alpha = 1);
73 MYRAMATH_EXPORT Vector<NumberZ> gemv(const CVectorRange<NumberZ>& a, const CMatrixRange<NumberZ>& B, char op, NumberZ alpha = 1);
75 
77 MYRAMATH_EXPORT Vector<NumberS> gemv(const CVectorRange<NumberS>& a, const CMatrixRange<NumberS>& B, NumberS alpha = 1);
79 MYRAMATH_EXPORT Vector<NumberD> gemv(const CVectorRange<NumberD>& a, const CMatrixRange<NumberD>& B, NumberD alpha = 1);
80 MYRAMATH_EXPORT Vector<NumberC> gemv(const CVectorRange<NumberC>& a, const CMatrixRange<NumberC>& B, NumberC alpha = 1);
81 MYRAMATH_EXPORT Vector<NumberZ> gemv(const CVectorRange<NumberZ>& a, const CMatrixRange<NumberZ>& B, NumberZ alpha = 1);
83 
85 MYRAMATH_EXPORT Vector<NumberS> operator * (const CVectorRange<NumberS>& a, const CMatrixRange<NumberS>& B);
87 MYRAMATH_EXPORT Vector<NumberD> operator * (const CVectorRange<NumberD>& a, const CMatrixRange<NumberD>& B);
88 MYRAMATH_EXPORT Vector<NumberC> operator * (const CVectorRange<NumberC>& a, const CMatrixRange<NumberC>& B);
89 MYRAMATH_EXPORT Vector<NumberZ> operator * (const CVectorRange<NumberZ>& a, const CMatrixRange<NumberZ>& B);
91 
92 } // namespace
93 
94 #endif
Definition: syntax.dox:1
Various utility functions/classes related to scalar Number types.