00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 class glue_minus
00023 {
00024 public:
00025
00026
00027
00028
00029 template<typename eT>
00030 inline static void apply(Mat<eT>& out, const Mat<eT>& A, const Mat<eT>& B);
00031
00032 template<typename eT>
00033 inline static void apply(Mat<eT>& out, const Mat<eT>& A, const Mat<eT>& B, const Mat<eT>& C);
00034
00035 template<typename eT>
00036 inline static void apply(Mat<eT>& out, const Glue< Mat<eT>, Mat<eT>, glue_minus>& X);
00037
00038 template<typename eT>
00039 inline static void apply(Mat<eT>& out, const Glue< Glue< Mat<eT>,Mat<eT>,glue_minus>, Mat<eT>, glue_minus>& X);
00040
00041 template<typename T1, typename T2>
00042 inline static void apply(Mat<typename T1::elem_type>& out, const Glue<T1,T2,glue_minus>& X);
00043
00044
00045
00046
00047 template<typename eT>
00048 inline static void apply_inplace(Mat<eT>& out, const Mat<eT>& B);
00049
00050 template<typename T1, typename op_type>
00051 inline static void apply_inplace(Mat<typename T1::elem_type>& out, const Op<T1, op_type>& X);
00052
00053 template<typename T1, typename T2, typename glue_type>
00054 inline static void apply_inplace(Mat<typename T1::elem_type>& out, const Glue<T1, T2, glue_type>& X);
00055
00056
00057
00058
00059 template<typename eT1, typename eT2>
00060 inline static void apply_mixed(Mat<typename promote_type<eT1,eT2>::result>& out, const Mat<eT1>& X, const Mat<eT2>& Y);
00061
00062 };
00063
00064
00065
00066
00067 class glue_minus_diag
00068 {
00069 public:
00070
00071 template<typename T1, typename T2>
00072 inline static void apply(Mat<typename T1::elem_type>& out, const T1& A, const Op<T2,op_diagmat>& B);
00073
00074 template<typename T1, typename T2>
00075 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_diagmat>& A, const T2& B);
00076
00077 template<typename T1, typename T2>
00078 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_diagmat>& A, const Op<T2,op_diagmat>& B);
00079
00080
00081
00082 template<typename T1, typename T2>
00083 inline static void apply(Mat<typename T1::elem_type>& out, const Glue<T1, Op<T2,op_diagmat>, glue_minus_diag>& X);
00084
00085 template<typename T1, typename T2>
00086 inline static void apply(Mat<typename T1::elem_type>& out, const Glue<Op<T1,op_diagmat>, T2, glue_minus_diag>& X);
00087
00088 template<typename T1, typename T2>
00089 inline static void apply(Mat<typename T1::elem_type>& out, const Glue<Op<T1,op_diagmat>, Op<T2,op_diagmat>, glue_minus_diag>& X);
00090
00091
00092 };
00093
00094