Operator_plus

Functions

template<typename T1 >
arma_inline const Base
< typename T1::elem_type, T1 > & 
operator+ (const Base< typename T1::elem_type, T1 > &X)
 unary plus operation (does nothing, but is required for completeness)
template<typename T1 >
arma_inline const eOp< T1,
eop_scalar_plus
operator+ (const Base< typename T1::elem_type, T1 > &X, const typename T1::elem_type k)
 Base + scalar.
template<typename T1 >
arma_inline const eOp< T1,
eop_scalar_plus
operator+ (const typename T1::elem_type k, const Base< typename T1::elem_type, T1 > &X)
 scalar + Base
template<typename T1 >
arma_inline Mat< typename
std::complex< typename
T1::pod_type > > 
operator+ (const Base< typename T1::pod_type, T1 > &X, const std::complex< typename T1::pod_type > &k)
 non-complex Base + complex scalar (experimental)
template<typename T1 >
arma_inline Mat< typename
std::complex< typename
T1::pod_type > > 
operator+ (const std::complex< typename T1::pod_type > &k, const Base< typename T1::pod_type, T1 > &X)
 complex scalar + non-complex Base (experimental)
template<typename T1 , typename T2 >
arma_inline const eGlue< T1,
T2, eglue_plus
operator+ (const Base< typename T1::elem_type, T1 > &X, const Base< typename T1::elem_type, T2 > &Y)
 addition of Base objects with same element type
template<typename T1 , typename T2 >
arma_inline Mat< typename
promote_type< typename
T1::elem_type, typename
T2::elem_type >::result > 
operator+ (const Base< typename force_different_type< typename T1::elem_type, typename T2::elem_type >::T1_result, T1 > &X, const Base< typename force_different_type< typename T1::elem_type, typename T2::elem_type >::T2_result, T2 > &Y)
 addition of Base objects with different element types

Function Documentation

template<typename T1 >
arma_inline const Base<typename T1::elem_type,T1>& operator+ ( const Base< typename T1::elem_type, T1 > &  X  )  [inline]

unary plus operation (does nothing, but is required for completeness)

Definition at line 27 of file operator_plus.hpp.

00028   {
00029   arma_extra_debug_sigprint();
00030   
00031   return X;
00032   }

template<typename T1 >
arma_inline const eOp<T1, eop_scalar_plus> operator+ ( const Base< typename T1::elem_type, T1 > &  X,
const typename T1::elem_type  k 
) [inline]

Base + scalar.

Definition at line 41 of file operator_plus.hpp.

References Base< elem_type, derived >::get_ref().

00042   {
00043   arma_extra_debug_sigprint();
00044   
00045   return eOp<T1, eop_scalar_plus>(X.get_ref(), k);
00046   }

template<typename T1 >
arma_inline const eOp<T1, eop_scalar_plus> operator+ ( const typename T1::elem_type  k,
const Base< typename T1::elem_type, T1 > &  X 
) [inline]

scalar + Base

Definition at line 55 of file operator_plus.hpp.

References Base< elem_type, derived >::get_ref().

00056   {
00057   arma_extra_debug_sigprint();
00058   
00059   return eOp<T1, eop_scalar_plus>(X.get_ref(), k);  // NOTE: order is swapped
00060   }

template<typename T1 >
arma_inline Mat<typename std::complex<typename T1::pod_type> > operator+ ( const Base< typename T1::pod_type, T1 > &  X,
const std::complex< typename T1::pod_type > &  k 
) [inline]

non-complex Base + complex scalar (experimental)

Definition at line 69 of file operator_plus.hpp.

References Base< elem_type, derived >::get_ref().

00073   {
00074   arma_extra_debug_sigprint();
00075   
00076   typedef typename std::complex<typename T1::pod_type> eT;
00077   typedef typename T1::pod_type                         T;
00078   
00079   const Proxy<T1> A(X.get_ref());
00080   
00081   Mat<eT> out(A.n_rows, A.n_cols);
00082   
00083   const u32 n_elem  = A.n_elem;
00084         eT* out_mem = out.memptr();
00085   
00086   for(u32 i=0; i<n_elem; ++i)
00087     {
00088     out_mem[i] = A[i] + k;
00089     }
00090   
00091   return out;
00092   }

template<typename T1 >
arma_inline Mat<typename std::complex<typename T1::pod_type> > operator+ ( const std::complex< typename T1::pod_type > &  k,
const Base< typename T1::pod_type, T1 > &  X 
) [inline]

complex scalar + non-complex Base (experimental)

Definition at line 101 of file operator_plus.hpp.

References Base< elem_type, derived >::get_ref().

00105   {
00106   arma_extra_debug_sigprint();
00107   
00108   typedef typename std::complex<typename T1::pod_type> eT;
00109   typedef typename T1::pod_type                         T;
00110   
00111   const Proxy<T1> A(X.get_ref());
00112   
00113   Mat<eT> out(A.n_rows, A.n_cols);
00114   
00115   const u32 n_elem  = A.n_elem;
00116         eT* out_mem = out.memptr();
00117   
00118   for(u32 i=0; i<n_elem; ++i)
00119     {
00120     out_mem[i] = k + A[i];
00121     }
00122   
00123   return out;
00124   }

template<typename T1 , typename T2 >
arma_inline const eGlue<T1, T2, eglue_plus> operator+ ( const Base< typename T1::elem_type, T1 > &  X,
const Base< typename T1::elem_type, T2 > &  Y 
) [inline]

addition of Base objects with same element type

Definition at line 133 of file operator_plus.hpp.

References Base< elem_type, derived >::get_ref().

00137   {
00138   arma_extra_debug_sigprint();
00139   
00140   return eGlue<T1, T2, eglue_plus>(X.get_ref(), Y.get_ref());
00141   }

template<typename T1 , typename T2 >
arma_inline Mat<typename promote_type<typename T1::elem_type, typename T2::elem_type>::result> operator+ ( const Base< typename force_different_type< typename T1::elem_type, typename T2::elem_type >::T1_result, T1 > &  X,
const Base< typename force_different_type< typename T1::elem_type, typename T2::elem_type >::T2_result, T2 > &  Y 
) [inline]

addition of Base objects with different element types

Definition at line 150 of file operator_plus.hpp.

References upgrade_val< T1, T2 >::apply(), promote_type< T1, T2 >::check(), Base< elem_type, derived >::get_ref(), Mat< eT >::memptr(), and Mat< eT >::n_elem.

00154   {
00155   arma_extra_debug_sigprint();
00156   
00157   typedef typename T1::elem_type eT1;
00158   typedef typename T2::elem_type eT2;
00159   
00160   typedef typename promote_type<eT1,eT2>::result out_eT;
00161   
00162   promote_type<eT1,eT2>::check();
00163   
00164   const Proxy<T1> A(X.get_ref());
00165   const Proxy<T2> B(Y.get_ref());
00166   
00167   arma_debug_assert_same_size(A, B, "matrix addition");
00168   
00169   Mat<out_eT> out(A.n_rows, A.n_cols);
00170 
00171         out_eT* out_mem = out.memptr();
00172   const u32     n_elem  = out.n_elem;
00173   
00174   for(u32 i=0; i<n_elem; ++i)
00175     {
00176     out_mem[i] = upgrade_val<eT1,eT2>::apply(A[i]) + upgrade_val<eT1,eT2>::apply(B[i]);
00177     }
00178   
00179   return out;
00180   }