/** \file strmodel1d.hpp \brief evaluating model from string, by usig muparser \author Junhua Gu */ #ifndef STRMODEL1D_HPP #define STRMODEL1D_HPP #define OPT_HEADER #include <core/fitter.hpp> #include <cmath> #include <sstream> #include <cassert> #include <muParser.h> #include <vector> #include <string> class strmodel1d :public opt_utilities::model<double,double,std::vector<double>,std::string> { private: mu::Parser mp; strmodel1d* do_clone()const; std::vector<double> par_vec; std::vector<std::string> par_names; std::string expr; std::string var_name; double x; void set_buildin_fun(); const char* do_get_type_name()const { return "parse a string as a model"; } public: double do_eval(const double& x,const std::vector<double>& p); strmodel1d(); strmodel1d(const strmodel1d& rhs); strmodel1d& operator=(const strmodel1d& rhs); void set_expr(const std::string& _expr, const std::vector<std::string>& _par_names, const std::string& _var_name); }; #endif //EOF