ROOT logo
// @(#)root/minuit2:$Id$
// Authors: M. Winkler, F. James, L. Moneta, A. Zsenei   2003-2005  

/**********************************************************************
 *                                                                    *
 * Copyright (c) 2005 LCG ROOT Math team,  CERN/PH-SFT                *
 *                                                                    *
 **********************************************************************/

#ifndef ROOT_Minuit2_MnFumiliMinimize
#define ROOT_Minuit2_MnFumiliMinimize

#include "Minuit2/MnApplication.h"
#include "Minuit2/FumiliMinimizer.h"
#include "Minuit2/FumiliFCNBase.h"

namespace ROOT {

   namespace Minuit2 {


// class FumiliFCNBase;
// class FCNBase;


//___________________________________________________________________________ 
/** 


API class for minimization using Fumili technology;
allows for user interaction: set/change parameters, do minimization,
change parameters, re-do minimization etc.; 
also used by MnMinos and MnContours;


 */

class MnFumiliMinimize : public MnApplication {

public:

   /// construct from FumiliFCNBase + std::vector for parameters and errors
   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) {}

   /// construct from FumiliFCNBase + std::vector for parameters and covariance
   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) {}

   /// construct from FumiliFCNBase + std::vector for parameters and MnUserCovariance
   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) {}

   /// construct from FumiliFCNBase + MnUserParameters
   MnFumiliMinimize(const FumiliFCNBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(FumiliMinimizer()), fFCN(fcn) {}

   /// construct from FumiliFCNBase + MnUserParameters + MnUserCovariance
   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) {}

   /// construct from FumiliFCNBase + MnUserParameterState + MnStrategy
   MnFumiliMinimize(const FumiliFCNBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(FumiliMinimizer()), fFCN(fcn) {}

   MnFumiliMinimize(const MnFumiliMinimize& migr) : MnApplication(migr.Fcnbase(), migr.State(), migr.Strategy(), migr.NumOfCalls()), fMinimizer(migr.fMinimizer), fFCN(migr.Fcnbase()) {}  

   virtual ~MnFumiliMinimize() { }

   const FumiliMinimizer& Minimizer() const {return fMinimizer;}

   const FumiliFCNBase & Fcnbase() const { return fFCN; }


   /// overwrite Minimize to use FumiliFCNBase
   virtual FunctionMinimum operator()(unsigned int = 0, double = 0.1);


private:

   FumiliMinimizer fMinimizer;
   const FumiliFCNBase & fFCN;

private:

   //forbidden assignment of migrad (const FumiliFCNBase& = )
   MnFumiliMinimize& operator=(const MnFumiliMinimize&) {return *this;}
};

  }  // namespace Minuit2

}  // namespace ROOT

#endif  // ROOT_Minuit2_MnFumiliMinimize
 MnFumiliMinimize.h:1
 MnFumiliMinimize.h:2
 MnFumiliMinimize.h:3
 MnFumiliMinimize.h:4
 MnFumiliMinimize.h:5
 MnFumiliMinimize.h:6
 MnFumiliMinimize.h:7
 MnFumiliMinimize.h:8
 MnFumiliMinimize.h:9
 MnFumiliMinimize.h:10
 MnFumiliMinimize.h:11
 MnFumiliMinimize.h:12
 MnFumiliMinimize.h:13
 MnFumiliMinimize.h:14
 MnFumiliMinimize.h:15
 MnFumiliMinimize.h:16
 MnFumiliMinimize.h:17
 MnFumiliMinimize.h:18
 MnFumiliMinimize.h:19
 MnFumiliMinimize.h:20
 MnFumiliMinimize.h:21
 MnFumiliMinimize.h:22
 MnFumiliMinimize.h:23
 MnFumiliMinimize.h:24
 MnFumiliMinimize.h:25
 MnFumiliMinimize.h:26
 MnFumiliMinimize.h:27
 MnFumiliMinimize.h:28
 MnFumiliMinimize.h:29
 MnFumiliMinimize.h:30
 MnFumiliMinimize.h:31
 MnFumiliMinimize.h:32
 MnFumiliMinimize.h:33
 MnFumiliMinimize.h:34
 MnFumiliMinimize.h:35
 MnFumiliMinimize.h:36
 MnFumiliMinimize.h:37
 MnFumiliMinimize.h:38
 MnFumiliMinimize.h:39
 MnFumiliMinimize.h:40
 MnFumiliMinimize.h:41
 MnFumiliMinimize.h:42
 MnFumiliMinimize.h:43
 MnFumiliMinimize.h:44
 MnFumiliMinimize.h:45
 MnFumiliMinimize.h:46
 MnFumiliMinimize.h:47
 MnFumiliMinimize.h:48
 MnFumiliMinimize.h:49
 MnFumiliMinimize.h:50
 MnFumiliMinimize.h:51
 MnFumiliMinimize.h:52
 MnFumiliMinimize.h:53
 MnFumiliMinimize.h:54
 MnFumiliMinimize.h:55
 MnFumiliMinimize.h:56
 MnFumiliMinimize.h:57
 MnFumiliMinimize.h:58
 MnFumiliMinimize.h:59
 MnFumiliMinimize.h:60
 MnFumiliMinimize.h:61
 MnFumiliMinimize.h:62
 MnFumiliMinimize.h:63
 MnFumiliMinimize.h:64
 MnFumiliMinimize.h:65
 MnFumiliMinimize.h:66
 MnFumiliMinimize.h:67
 MnFumiliMinimize.h:68
 MnFumiliMinimize.h:69
 MnFumiliMinimize.h:70
 MnFumiliMinimize.h:71
 MnFumiliMinimize.h:72
 MnFumiliMinimize.h:73
 MnFumiliMinimize.h:74
 MnFumiliMinimize.h:75
 MnFumiliMinimize.h:76
 MnFumiliMinimize.h:77
 MnFumiliMinimize.h:78
 MnFumiliMinimize.h:79
 MnFumiliMinimize.h:80
 MnFumiliMinimize.h:81
 MnFumiliMinimize.h:82
 MnFumiliMinimize.h:83
 MnFumiliMinimize.h:84
 MnFumiliMinimize.h:85
 MnFumiliMinimize.h:86
 MnFumiliMinimize.h:87
 MnFumiliMinimize.h:88