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