00001
00002
00003
00004
00005
00006
00007
00008
00009
00010 #ifndef ROOT_Minuit2_MnScan
00011 #define ROOT_Minuit2_MnScan
00012
00013 #include "Minuit2/MnApplication.h"
00014 #include "Minuit2/ScanMinimizer.h"
00015
00016 namespace ROOT {
00017
00018 namespace Minuit2 {
00019
00020
00021 class FCNBase;
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 class MnScan : public MnApplication {
00032
00033 public:
00034
00035
00036 MnScan(const FCNBase& fcn, const std::vector<double>& par, const std::vector<double>& err, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par,err), MnStrategy(stra)), fMinimizer(ScanMinimizer()) {}
00037
00038
00039 MnScan(const FCNBase& fcn, const std::vector<double>& par, unsigned int nrow, const std::vector<double>& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov, nrow), MnStrategy(stra)), fMinimizer(ScanMinimizer()) {}
00040
00041
00042 MnScan(const FCNBase& fcn, const std::vector<double>& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(ScanMinimizer()) {}
00043
00044
00045 MnScan(const FCNBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(ScanMinimizer()) {}
00046
00047
00048 MnScan(const FCNBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(ScanMinimizer()) {}
00049
00050
00051 MnScan(const FCNBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(ScanMinimizer()) {}
00052
00053 MnScan(const MnScan& migr) : MnApplication(migr.Fcnbase(), migr.State(), migr.Strategy(), migr.NumOfCalls()), fMinimizer(migr.fMinimizer) {}
00054
00055 ~MnScan() {}
00056
00057 const ModularFunctionMinimizer& Minimizer() const {return fMinimizer;}
00058
00059 std::vector<std::pair<double, double> > Scan(unsigned int par, unsigned int maxsteps = 41, double low = 0., double high = 0.);
00060
00061 private:
00062
00063 ScanMinimizer fMinimizer;
00064
00065 private:
00066
00067
00068 MnScan& operator=(const MnScan&) {return *this;}
00069 };
00070
00071 }
00072
00073 }
00074
00075 #endif // ROOT_Minuit2_MnScan