aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--error_estimator/error_estimator.hpp38
-rw-r--r--example/test_fitter.cpp3
-rw-r--r--interface/type_depository.hpp9
3 files changed, 44 insertions, 6 deletions
diff --git a/error_estimator/error_estimator.hpp b/error_estimator/error_estimator.hpp
index e76fb12..e7a0cc0 100644
--- a/error_estimator/error_estimator.hpp
+++ b/error_estimator/error_estimator.hpp
@@ -8,12 +8,39 @@
#define ERROR_EST
#include <core/fitter.hpp>
#include <core/freeze_param.hpp>
+#include <interface/type_depository.hpp>
+#include <math/num_diff.hpp>
#include <iostream>
#include <vector>
#include <string>
namespace opt_utilities
{
+ template <typename Ty,typename Tx,typename Tp,typename Ts,typename Tstr>
+ typename element_type_trait<Tp>::element_type estimate_error_hessian(fitter<Ty,Tx,Tp,Ts>& fit,const Tstr& pname,const Ts& dchi)
+ {
+ size_t porder=fit.get_param_order(pname);
+ holder<param_modifier<Ty,Tx,Tp,Tstr> > h;
+ try
+ {
+ h.reset(fit.get_param_modifier().clone());
+ }
+ catch(const param_modifier_undefined&)
+ {
+ h.reset(0);
+ }
+ fit.clear_param_modifier();
+ Tp p=fit.get_all_params();
+ Ts a=hessian(fit.get_statistic(),p,porder,porder)/2;
+ if(h.get())
+ {
+ fit.set_param_modifier(*(h.get()));
+ }
+ fit.fit();
+ return std::sqrt(dchi/a);
+ }
+
+
/**
\brief calculate the error boundary of a fit, according to the given delta statistic.
\param fit the fitter that has a sucessful fit result
@@ -24,7 +51,7 @@ namespace opt_utilities
\param precision determine how precise the error bounds should be determined
*/
template <typename Ty,typename Tx,typename Tp,typename Ts,typename Tstr>
- void estimate_error(fitter<Ty,Tx,Tp,Ts>& fit,const Tstr& pname,typename element_type_trait<Tp>::element_type& lower,typename element_type_trait<Tp>::element_type& upper,const Ts& dchi,const Ts& precision)
+ void estimate_error_directly(fitter<Ty,Tx,Tp,Ts>& fit,const Tstr& pname,typename element_type_trait<Tp>::element_type& lower,typename element_type_trait<Tp>::element_type& upper,const Ts& dchi,const Ts& precision)
{
typedef typename element_type_trait<Tp>::element_type Tpe;
std::vector<Tstr> pnames;
@@ -175,6 +202,15 @@ namespace opt_utilities
fit.fit();
}
+
+ template <typename Ty,typename Tx,typename Tp,typename Ts,typename Tstr>
+ void estimate_error(fitter<Ty,Tx,Tp,Ts>& fit,const Tstr& pname,typename element_type_trait<Tp>::element_type& lower,typename element_type_trait<Tp>::element_type& upper,const Ts& dchi,const Ts& precision)
+ {
+ typename element_type_trait<Tp>::element_type e=estimate_error_hessian(fit,pname,dchi);
+ lower=fit.get_param_value(pname)-e*2;
+ upper=fit.get_param_value(pname)+e*2;
+ estimate_error_directly(fit,pname,lower,upper,dchi,precision);
+ }
}
diff --git a/example/test_fitter.cpp b/example/test_fitter.cpp
index 718d029..47a81ec 100644
--- a/example/test_fitter.cpp
+++ b/example/test_fitter.cpp
@@ -60,7 +60,6 @@ int main()
double lower=3;
double upper=6;
-
- estimate_error(f,std::string("b"),lower,upper,1.,1E-10);
+ estimate_error(f,std::string("k"),lower,upper,1.,1E-10);
std::cout<<lower<<"\t"<<upper<<endl;
}
diff --git a/interface/type_depository.hpp b/interface/type_depository.hpp
index d0e0bfb..9bacc9b 100644
--- a/interface/type_depository.hpp
+++ b/interface/type_depository.hpp
@@ -53,7 +53,7 @@ namespace opt_utilities
~holder()
{
- delete ptr;
+ destroy();
}
holder& operator=(const holder& rhs)
@@ -62,7 +62,7 @@ namespace opt_utilities
{
return *this;
}
- delete ptr;
+ destroy();
ptr=rhs.ptr;
const_cast<holder&>(rhs).ptr=0;
}
@@ -77,7 +77,10 @@ namespace opt_utilities
void destroy()
{
- delete ptr;
+ if(ptr)
+ {
+ ptr->destroy();
+ }
}
T* get()const