diff options
| author | astrojhgu <astrojhgu@ed2142bd-67ad-457f-ba7c-d818d4011675> | 2009-12-17 17:01:15 +0000 | 
|---|---|---|
| committer | astrojhgu <astrojhgu@ed2142bd-67ad-457f-ba7c-d818d4011675> | 2009-12-17 17:01:15 +0000 | 
| commit | 4170b13f464439ab97efadb210dab0d749fa4b42 (patch) | |
| tree | f6d31514c19a9a015c4d22477f5a3fb8bccd250b /vmodels | |
| parent | eeafd6e502bc60da664de3cf0eb9251f349df228 (diff) | |
| download | opt-utilities-4170b13f464439ab97efadb210dab0d749fa4b42.tar.bz2 | |
rename vmodel to vmodels
git-svn-id: file:///home/svn/opt_utilities@103 ed2142bd-67ad-457f-ba7c-d818d4011675
Diffstat (limited to 'vmodels')
| -rw-r--r-- | vmodels/bl.hpp | 67 | ||||
| -rw-r--r-- | vmodels/bpl.hpp | 67 | ||||
| -rw-r--r-- | vmodels/bremss.hpp | 50 | ||||
| -rw-r--r-- | vmodels/gauss1d.hpp | 53 | ||||
| -rw-r--r-- | vmodels/lin1d.hpp | 58 | ||||
| -rw-r--r-- | vmodels/powerlaw.hpp | 50 | 
6 files changed, 345 insertions, 0 deletions
| diff --git a/vmodels/bl.hpp b/vmodels/bl.hpp new file mode 100644 index 0000000..84d6ca5 --- /dev/null +++ b/vmodels/bl.hpp @@ -0,0 +1,67 @@ +#ifndef BROKEN_LINE_MODEL_H_ +#define BROKEN_LINE_MODEL_H_ +#define OPT_HEADER +#include <core/fitter.hpp> +#include <cmath> +#include <misc/optvec.hpp> +namespace opt_utilities +{ +  template <typename T> +  class bl +    :public model<optvec<T>,optvec<T>,optvec<T>,std::string> +  { +  private: +    model<optvec<T>,optvec<T>,optvec<T>,std::string >* do_clone()const +    { +      return new bl<T>(*this); +    } +     +    const char* do_get_type_name()const +    { +      return "broken linear model"; +    } +  public: +    bl() +    { +      this->push_param_info(param_info<optvec<T> >("break point y value",1)); +      this->push_param_info(param_info<optvec<T> >("break point x value",1)); +      this->push_param_info(param_info<optvec<T> >("slop 1",1)); +      this->push_param_info(param_info<optvec<T> >("slop 2",1)); +    } + +  public: +    optvec<T> do_eval(const optvec<T>& x,const optvec<T>& param) +    { +      T x_b=get_element(param,0); +      T f_b=get_element(param,1); +      T k1=get_element(param,2); +      T k2=get_element(param,3); +      optvec<double> result(x.size()); +      for(int i=0;i<x.size();++i) +	{ +	  if(x[i]<x_b) +	    { +	      result[i]=k1*(x[i]-x_b)+f_b; +	    } +	  else +	    { +	      result[i]=k2*(x[i]-x_b)+f_b; +	    } +	} +      return result; +    } + +  private: +    std::string do_get_information()const +    { +      return "broken linear model\n" +	"y=k1*(x-x_b)+y_b for x<x_b\n" +	"y=k2*(x-x_b)+y_b otherwise\n"; +    } +  }; +} + + + +#endif +//EOF diff --git a/vmodels/bpl.hpp b/vmodels/bpl.hpp new file mode 100644 index 0000000..e99efe3 --- /dev/null +++ b/vmodels/bpl.hpp @@ -0,0 +1,67 @@ +#ifndef BROKEN_POWER_LAW_MODEL_H_ +#define BROKEN_POWER_LAW_MODEL_H_ +#define OPT_HEADER +#include <core/fitter.hpp> +#include <cmath> +#include <misc/optvec.hpp> + +namespace opt_utilities +{ +  template <typename T> +  class bpl1d +    :public model<optvec<T>,optvec<T>,optvec<T>,std::string> +  { +  private: +    bpl1d* do_clone()const +    { +      return new bpl1d<T>(*this); +    } + +    const char* do_get_type_name()const +    { +      return "broken power law"; +    } +  public: +    bpl1d() +    { +      this->push_param_info(param_info<optvec<T> >("bpx",1)); +      this->push_param_info(param_info<optvec<T> >("bpy",1)); +      this->push_param_info(param_info<optvec<T> >("gamma1",1)); +      this->push_param_info(param_info<optvec<T> >("gamma2",1)); +    } + +    optvec<T> do_eval(const optvec<T>& x,const optvec<T>& param) +    { +      T x_b=get_element(param,0); +      T f_b=get_element(param,1); +      T gamma1=get_element(param,2); +      T gamma2=get_element(param,3); +       +      optvec<T> result(x.size()); +      for(int i=0;i<result.size();++i) +	{ +	  if(x[i]<x_b) +	    { +	      result[i]=f_b*pow(x[i],gamma1)/pow(x_b,gamma1); +	    } +	  else +	    { +	      result[i]=f_b*pow(x[i],gamma2)/pow(x_b,gamma2); +	    } +	} +      return result; +    } +     + +  private: +    std::string do_get_information()const +    { +      return ""; +    } +  }; +} + + + +#endif +//EOF diff --git a/vmodels/bremss.hpp b/vmodels/bremss.hpp new file mode 100644 index 0000000..12e1f71 --- /dev/null +++ b/vmodels/bremss.hpp @@ -0,0 +1,50 @@ +#ifndef BREMSS_MODEL_H_ +#define BREMSS_MODEL_H_ +#define OPT_HEADER +#include <core/fitter.hpp> +#include <cmath> +#include <misc/optvec.hpp> + +namespace opt_utilities +{ +  template <typename T> +  class bremss +    :public model<optvec<T>,optvec<T>,optvec<T>,std::string> +  { +  private: +    bremss* do_clone()const +    { +      return new bremss<T>(*this); +    } + +    const char* do_get_type_name()const +    { +      return "Bremsstrahlung emission"; +    } +  public: +    bremss() +    { +      this->push_param_info(param_info<optvec<T> >("norm",1)); +      this->push_param_info(param_info<optvec<T> >("kT",1)); +    } + +    optvec<T> do_eval(const optvec<T>& x,const optvec<T>& param) +    { +      T norm=get_element(param,0); +      T kT=get_element(param,1); +       +      return norm*sqrt(kT)*exp(-x/kT); +    } + +  private: +    std::string do_get_information()const +    { +      return ""; +    } +  }; +} + + + +#endif +//EOF diff --git a/vmodels/gauss1d.hpp b/vmodels/gauss1d.hpp new file mode 100644 index 0000000..5576c89 --- /dev/null +++ b/vmodels/gauss1d.hpp @@ -0,0 +1,53 @@ +#ifndef GAUSS_MODEL_H_ +#define GAUSS_MODEL_H_ +#define OPT_HEADER +#include <core/fitter.hpp> +#include <cmath> +#include <misc/optvec.hpp> + +namespace opt_utilities +{ +  template <typename T> +  class gauss1d +    :public model<optvec<T>,optvec<T>,optvec<T>,std::string> +  { +  private: +    gauss1d* do_clone()const +    { +      return new gauss1d<T>(*this); +    } + +    const char* do_get_type_name()const +    { +      return "1d gaussian"; +    } +  public: +    gauss1d() +    { +      this->push_param_info(param_info<optvec<T> >("N",1)); +      this->push_param_info(param_info<optvec<T> >("x0",0)); +      this->push_param_info(param_info<optvec<T> >("sigma",1)); +    } + +  public: +    optvec<T> do_eval(const optvec<T>& x,const optvec<T>& param) +    { +      T N=get_element(param,0); +      T x0=get_element(param,1); +      T sigma=get_element(param,2); +      optvec<T> y=(x-x0)/2./sigma; +      return N*exp(-y*y); +    } + +  private: +    std::string do_get_information()const +    { +      return ""; +    } +  }; +} + + + +#endif +//EOF diff --git a/vmodels/lin1d.hpp b/vmodels/lin1d.hpp new file mode 100644 index 0000000..8ca8074 --- /dev/null +++ b/vmodels/lin1d.hpp @@ -0,0 +1,58 @@ +#ifndef VLINEAR_MODEL_H_ +#define VLINEAR_MODEL_H_ +#define OPT_HEADER +#include <core/fitter.hpp> +#include <misc/optvec.hpp> +#include <cmath> + +namespace opt_utilities +{ +  template <typename T> +  class lin1d +    :public model<optvec<T>,optvec<T>,optvec<T>,std::string> +  { +    typedef optvec<T> Tv; +  private: +    lin1d<T>* do_clone()const +    { +      return new lin1d<T>(*this); +    } + +    const char* do_get_type_name()const +    { +      return "1d linear model"; +    } +  public: +    lin1d() +    { +      this->push_param_info(param_info<Tv>("k",1)); +      this->push_param_info(param_info<Tv>("b",0)); +    } + +  public: +    Tv do_eval(const Tv& x,const Tv& param) +    { +      Tv result(x.size()); +       +      //return x*get_element(param,0)+get_element(param,1); +      for(size_t i=0;i!=x.size();++i) +	{ +	  result[i]=param[0]*x[i]+param[1]; +	} +      return result; +    } + +  private: +    std::string do_get_information()const +    { +      return "<math><mrow> <mtext>f(x;k,b)=k x+b</mtext>		\ +    </mrow>								\ +</math>"; +    } +  }; +} + + + +#endif +//EOF diff --git a/vmodels/powerlaw.hpp b/vmodels/powerlaw.hpp new file mode 100644 index 0000000..1f05301 --- /dev/null +++ b/vmodels/powerlaw.hpp @@ -0,0 +1,50 @@ +#ifndef POWER_LAW_MODEL_H_ +#define POWER_LAW_MODEL_H_ +#define OPT_HEADER +#include <core/fitter.hpp> +#include <cmath> +#include <misc/optvec.hpp> + +namespace opt_utilities +{ +  template <typename T> +  class powerlaw +    :public model<optvec<T>,optvec<T>,optvec<T>,std::string> +  { +  private: +    powerlaw* do_clone()const +    { +      return new powerlaw<T>(*this); +    } + +    const char* do_get_type_name()const +    { +      return "1d power law"; +    } +  public: +    powerlaw() +    { +      this->push_param_info(param_info<optvec<T> >("Ampl",1)); +      this->push_param_info(param_info<optvec<T> >("gamma",1)); +    } + +    optvec<T> do_eval(const optvec<T>& x,const optvec<T>& param) +    { +      T A=get_element(param,0); +      T gamma=get_element(param,1); +      return A*pow(x,gamma); +    } + +  private: +    std::string do_get_information()const +    { +      return "Simple power law model\n" +	"y=A*x^gamma\n"; +    } +  }; +} + + + +#endif +//EOF | 
