00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #ifndef TVMET_META_GEMV_H
00025 #define TVMET_META_GEMV_H
00026
00027 #include <tvmet/xpr/Null.h>
00028
00029 namespace tvmet {
00030
00031 namespace meta {
00032
00033
00042 template<std::size_t Rows, std::size_t Cols,
00043 std::size_t J>
00044 class gemv
00045 {
00046 gemv();
00047 gemv(const gemv&);
00048 gemv& operator=(const gemv&);
00049
00050 private:
00051 enum {
00052 doIt = J < (Cols-1)
00053 };
00054
00055 public:
00057 template<class E1, class E2>
00058 static inline
00059 typename PromoteTraits<
00060 typename E1::value_type,
00061 typename E2::value_type
00062 >::value_type
00063 prod(const E1& lhs, const E2& rhs, std::size_t i) {
00064 return lhs(i, J) * rhs(J)
00065 + gemv<Rows * doIt, Cols * doIt,
00066 (J+1)* doIt>::prod(lhs, rhs, i);
00067 }
00068 };
00069
00070
00075 template<>
00076 class gemv<0,0,0>
00077 {
00078 gemv();
00079 gemv(const gemv&);
00080 gemv& operator=(const gemv&);
00081
00082 public:
00083 template<class E1, class E2>
00084 static inline
00085 XprNull prod(const E1&, const E2&, std::size_t) {
00086 return XprNull();
00087 }
00088 };
00089
00090
00091 }
00092
00093 }
00094
00095 #endif
00096
00097
00098
00099
00100