MnMinimize.h

Go to the documentation of this file.
00001 // @(#)root/minuit2:$Id: MnMinimize.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_MnMinimize
00011 #define ROOT_Minuit2_MnMinimize
00012 
00013 #include "Minuit2/MnApplication.h"
00014 #include "Minuit2/CombinedMinimizer.h"
00015 
00016 namespace ROOT {
00017 
00018    namespace Minuit2 {
00019 
00020 
00021 class FCNBase;
00022 
00023 /** API class for minimization using Variable Metric technology ("MIGRAD");
00024     allows for user interaction: set/change parameters, do minimization,
00025     change parameters, re-do minimization etc.; 
00026     also used by MnMinos and MnContours;
00027  */
00028 
00029 class MnMinimize : public MnApplication {
00030 
00031 public:
00032 
00033    /// construct from FCNBase + std::vector for parameters and errors
00034    MnMinimize(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(CombinedMinimizer()) {}
00035 
00036    /// construct from FCNBase + std::vector for parameters and covariance
00037    MnMinimize(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(CombinedMinimizer()) {}
00038 
00039    /// construct from FCNBase + std::vector for parameters and MnUserCovariance
00040    MnMinimize(const FCNBase& fcn, const std::vector<double>& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(CombinedMinimizer()) {}
00041 
00042    /// construct from FCNBase + MnUserParameters
00043    MnMinimize(const FCNBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(CombinedMinimizer()) {}
00044 
00045    /// construct from FCNBase + MnUserParameters + MnUserCovariance
00046    MnMinimize(const FCNBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(CombinedMinimizer()) {}
00047 
00048    /// construct from FCNBase + MnUserParameterState + MnStrategy
00049    MnMinimize(const FCNBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(CombinedMinimizer()) {}
00050 
00051    // interfaces using FCNGradientBase
00052 
00053    /// construct from FCNGradientBase + std::vector for parameters and errors
00054    MnMinimize(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(CombinedMinimizer()) {}
00055 
00056    /// construct from FCNGradientBase + std::vector for parameters and covariance
00057    MnMinimize(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(CombinedMinimizer()) {}
00058 
00059    /// construct from FCNGradientBase + std::vector for parameters and MnUserCovariance
00060    MnMinimize(const FCNGradientBase& fcn, const std::vector<double>& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(CombinedMinimizer()) {}
00061 
00062    /// construct from FCNGradientBase + MnUserParameters
00063    MnMinimize(const FCNGradientBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(CombinedMinimizer()) {}
00064 
00065    /// construct from FCNGradientBase + MnUserParameters + MnUserCovariance
00066    MnMinimize(const FCNGradientBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(CombinedMinimizer()) {}
00067 
00068    /// construct from FCNGradientBase + MnUserParameterState + MnStrategy
00069    MnMinimize(const FCNGradientBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(CombinedMinimizer()) {}
00070 
00071 
00072    MnMinimize(const MnMinimize& migr) : MnApplication(migr.Fcnbase(), migr.State(), migr.Strategy(), migr.NumOfCalls()), fMinimizer(migr.fMinimizer) {}  
00073 
00074    ~MnMinimize() {}
00075 
00076    const ModularFunctionMinimizer& Minimizer() const {return fMinimizer;}
00077 
00078 private:
00079 
00080    CombinedMinimizer fMinimizer;
00081 
00082 private:
00083 
00084    //forbidden assignment operator
00085    MnMinimize& operator=(const MnMinimize&) {return *this;}
00086 };
00087 
00088   }  // namespace Minuit2
00089 
00090 }  // namespace ROOT
00091 
00092 #endif  // ROOT_Minuit2_MnMinimize

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