op_diagmat_proto.hpp
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 class op_diagmat
00023 {
00024 private:
00025
00026 template<typename eT>
00027 inline static void zero_offdiag(Mat<eT>& X);
00028
00029
00030 public:
00031
00032 template<typename T1>
00033 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_diagmat>& in);
00034
00035 template<typename T1, typename T2>
00036 inline static void apply(Mat<typename T1::elem_type>& out, const Op< Glue<T1,T2, glue_div>, op_diagmat>& in);
00037
00038 template<typename T1, typename T2>
00039 inline static void apply(Mat<typename T1::elem_type>& out, const Op< Glue<T1,T2, glue_minus>, op_diagmat>& in);
00040
00041 template<typename T1, typename T2>
00042 inline static void apply(Mat<typename T1::elem_type>& out, const Op< Glue<T1,T2, glue_plus>, op_diagmat>& in);
00043
00044 template<typename T1, typename T2>
00045 inline static void apply(Mat<typename T1::elem_type>& out, const Op< Glue<T1,T2, glue_schur>, op_diagmat>& in);
00046
00047 template<typename T1, typename T2>
00048 inline static void apply(Mat<typename T1::elem_type>& out, const Op< Glue<T1,T2, glue_times>, op_diagmat>& in);
00049
00050 };
00051
00052
00053 class op_diagmat_vec
00054 {
00055 public:
00056
00057 template<typename T1>
00058 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_diagmat_vec>& in);
00059 };
00060
00061
00062