MnMigrad.h

Go to the documentation of this file.
00001 // @(#)root/minuit2:$Id: MnMigrad.h 23654 2008-05-06 07:30:34Z moneta $
00002 // Authors: M. Winkler, F. James, L. Moneta, A. Zsenei   2003-2005  
00003 
00004 /**********************************************************************
00005  *                                                                    *
00006  * Copyright (c) 2005 LCG ROOT Math team,  CERN/PH-SFT                *
00007  *                                                                    *
00008  **********************************************************************/
00009 
00010 #ifndef ROOT_Minuit2_MnMigrad
00011 #define ROOT_Minuit2_MnMigrad
00012 
00013 #include "Minuit2/MnApplication.h"
00014 #include "Minuit2/VariableMetricMinimizer.h"
00015 
00016 namespace ROOT {
00017 
00018    namespace Minuit2 {
00019 
00020 
00021 class FCNBase;
00022 
00023 //_____________________________________________________________________________
00024 /**
00025    API class for minimization using Variable Metric technology ("MIGRAD");
00026     allows for user interaction: set/change parameters, do minimization,
00027     change parameters, re-do minimization etc.; 
00028     also used by MnMinos and MnContours;
00029  */
00030 
00031 class MnMigrad : public MnApplication {
00032 
00033 public:
00034 
00035    /// construct from FCNBase + std::vector for parameters and errors
00036    MnMigrad(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(VariableMetricMinimizer()) {}
00037 
00038    /// construct from FCNBase + std::vector for parameters and covariance
00039    MnMigrad(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(VariableMetricMinimizer()) {}
00040 
00041    /// construct from FCNBase + std::vector for parameters and MnUserCovariance
00042    MnMigrad(const FCNBase& fcn, const std::vector<double>& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00043 
00044    /// construct from FCNBase + MnUserParameters
00045    MnMigrad(const FCNBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00046 
00047    /// construct from FCNBase + MnUserParameters + MnUserCovariance
00048    MnMigrad(const FCNBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00049 
00050    /// construct from FCNBase + MnUserParameterState + MnStrategy
00051    MnMigrad(const FCNBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(VariableMetricMinimizer()) {}
00052 
00053    // constructs from gradient FCN
00054 
00055    /// construct from FCNGradientBase + std::vector for parameters and errors
00056    MnMigrad(const FCNGradientBase& fcn, const std::vector<double>& par, const std::vector<double>& err, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par,err), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00057 
00058    /// construct from FCNGradientBase + std::vector for parameters and covariance
00059    MnMigrad(const FCNGradientBase& 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(VariableMetricMinimizer()) {}
00060 
00061    /// construct from FCNGradientBase + std::vector for parameters and MnUserCovariance
00062    MnMigrad(const FCNGradientBase& fcn, const std::vector<double>& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00063 
00064    /// construct from FCNGradientBase + MnUserParameters
00065    MnMigrad(const FCNGradientBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00066 
00067    /// construct from FCNGradientBase + MnUserParameters + MnUserCovariance
00068    MnMigrad(const FCNGradientBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}
00069 
00070    /// construct from FCNGradientBase + MnUserParameterState + MnStrategy
00071    MnMigrad(const FCNGradientBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(VariableMetricMinimizer()) {}
00072 
00073    MnMigrad(const MnMigrad& migr) : MnApplication(migr.Fcnbase(), migr.State(), migr.Strategy(), migr.NumOfCalls()), fMinimizer(migr.fMinimizer) {}  
00074 
00075    ~MnMigrad() {}
00076 
00077    const ModularFunctionMinimizer& Minimizer() const {return fMinimizer;}
00078 
00079 private:
00080 
00081    VariableMetricMinimizer fMinimizer;
00082 
00083 private:
00084 
00085    //forbidden assignment of migrad (const FCNBase& = )
00086    MnMigrad& operator=(const MnMigrad&) {return *this;}
00087 };
00088 
00089   }  // namespace Minuit2
00090 
00091 }  // namespace ROOT
00092 
00093 #endif  // ROOT_Minuit2_MnMigrad

Generated on Tue Jul 5 14:25:44 2011 for ROOT_528-00b_version by  doxygen 1.5.1