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