00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 #ifndef RTOPPACK_UNARY_FUNC_PTR_HPP
00030 #define RTOPPACK_UNARY_FUNC_PTR_HPP
00031
00032 #include "RTOpPack_TOpUnaryFuncPtrDecl.hpp"
00033
00034 namespace RTOpPack {
00035
00036 template<class Scalar>
00037 TOpUnaryFuncPtr<Scalar>::TOpUnaryFuncPtr()
00038 :RTOpT<Scalar>("TOpUnaryFuncPtr")
00039 {
00040 set_initialized();
00041 }
00042
00043 template<class Scalar>
00044 TOpUnaryFuncPtr<Scalar>::TOpUnaryFuncPtr(
00045 unary_func_ptr_t unary_func_ptr
00046 ,const std::string &op_name
00047 )
00048 :RTOpT<Scalar>("TOpUnaryFuncPtr")
00049 {
00050 initialize(unary_func_ptr,op_name);
00051 }
00052
00053 template<class Scalar>
00054 void TOpUnaryFuncPtr<Scalar>::initialize(
00055 unary_func_ptr_t unary_func_ptr
00056 ,const std::string &op_name
00057 )
00058 {
00059 TEST_FOR_EXCEPTION( unary_func_ptr==NULL, std::invalid_argument, "Error!" );
00060 unary_func_ptr_ = unary_func_ptr;
00061 op_name_ = op_name;
00062 }
00063
00064 template<class Scalar>
00065 void TOpUnaryFuncPtr<Scalar>::set_initialized(
00066 unary_func_ptr_t *unary_func_ptr
00067 ,std::string *op_name
00068 )
00069 {
00070 if(unary_func_ptr) *unary_func_ptr = unary_func_ptr_;
00071 if(op_name) *op_name = op_name_;
00072
00073 unary_func_ptr_ = NULL;
00074 op_name_ = "uninitialized()";
00075 }
00076
00077
00078
00079 template<class Scalar>
00080 const char* TOpUnaryFuncPtr<Scalar>::op_name() const
00081 {
00082 return op_name_.c_str();
00083 }
00084
00085 template<class Scalar>
00086 void TOpUnaryFuncPtr<Scalar>::apply_op(
00087 const int num_vecs, const SubVectorT<Scalar> sub_vecs[]
00088 ,const int num_targ_vecs, const MutableSubVectorT<Scalar> targ_sub_vecs[]
00089 ,ReductTarget *reduct_obj
00090 ) const
00091 {
00092 TEST_FOR_EXCEPTION( num_vecs != 1 || sub_vecs == NULL, std::invalid_argument, "Error!" );
00093 TEST_FOR_EXCEPTION( num_targ_vecs != 1 || targ_sub_vecs == NULL, std::invalid_argument, "Error!" );
00094 TEST_FOR_EXCEPTION( reduct_obj != NULL, std::invalid_argument, "Error!" );
00095 TEST_FOR_EXCEPTION( sub_vecs[0].stride() != 1, std::invalid_argument, "Error, can't handle non-unit strides here!" );
00096 TEST_FOR_EXCEPTION( targ_sub_vecs[0].stride() != 1, std::invalid_argument, "Error, can't handle non-unit strides here!" );
00097 TEST_FOR_EXCEPTION( sub_vecs[0].subDim() != targ_sub_vecs[0].subDim(), std::invalid_argument, "Error!" );
00098 TEST_FOR_EXCEPTION( sub_vecs[0].globalOffset() != targ_sub_vecs[0].globalOffset(), std::invalid_argument, "Error!" );
00099
00100 unary_func_ptr_( sub_vecs[0].values(), sub_vecs[0].subDim(), targ_sub_vecs[0].values() );
00101
00102 }
00103
00104 }
00105
00106 #endif // RTOPPACK_UNARY_FUNC_PTR_HPP