ROOT logo
// @(#)root/minuit2:$Id: MnMigrad.h 23654 2008-05-06 07:30:34Z moneta $
// Authors: M. Winkler, F. James, L. Moneta, A. Zsenei   2003-2005  

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

#ifndef ROOT_Minuit2_MnMigrad
#define ROOT_Minuit2_MnMigrad

#include "Minuit2/MnApplication.h"
#include "Minuit2/VariableMetricMinimizer.h"

namespace ROOT {

   namespace Minuit2 {


class FCNBase;

//_____________________________________________________________________________
/**
   API class for minimization using Variable Metric technology ("MIGRAD");
    allows for user interaction: set/change parameters, do minimization,
    change parameters, re-do minimization etc.; 
    also used by MnMinos and MnContours;
 */

class MnMigrad : public MnApplication {

public:

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

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

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

   /// construct from FCNBase + MnUserParameters
   MnMigrad(const FCNBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}

   /// construct from FCNBase + MnUserParameters + MnUserCovariance
   MnMigrad(const FCNBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}

   /// construct from FCNBase + MnUserParameterState + MnStrategy
   MnMigrad(const FCNBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(VariableMetricMinimizer()) {}

   // constructs from gradient FCN

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

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

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

   /// construct from FCNGradientBase + MnUserParameters
   MnMigrad(const FCNGradientBase& fcn, const MnUserParameters& par, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}

   /// construct from FCNGradientBase + MnUserParameters + MnUserCovariance
   MnMigrad(const FCNGradientBase& fcn, const MnUserParameters& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(VariableMetricMinimizer()) {}

   /// construct from FCNGradientBase + MnUserParameterState + MnStrategy
   MnMigrad(const FCNGradientBase& fcn, const MnUserParameterState& par, const MnStrategy& str) : MnApplication(fcn, MnUserParameterState(par), str), fMinimizer(VariableMetricMinimizer()) {}

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

   ~MnMigrad() {}

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

private:

   VariableMetricMinimizer fMinimizer;

private:

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

  }  // namespace Minuit2

}  // namespace ROOT

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