MnFumiliMinimize.h

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

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