// @(#)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_MnSimplex
#define ROOT_Minuit2_MnSimplex

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

namespace ROOT {

   namespace Minuit2 {


class FCNBase;

//_________________________________________________________________________
/**
    API class for minimization using the Simplex method, which does not need and use
    the derivatives of the function, but only function values.
    More information on the minimization method is available
    <A HREF="http://seal.web.cern.ch/mathlibs/documents/minuit/mntutorial.pdf">here</A>.

    It allows for user interaction: set/change parameters, do minimization,
    change parameters, re-do minimization etc.;
 */

class MnSimplex : public MnApplication {

public:

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

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

   /// construct from FCNBase + std::vector for parameters and MnUserCovariance
   MnSimplex(const FCNBase& fcn, const std::vector<double>& par, const MnUserCovariance& cov, unsigned int stra = 1) : MnApplication(fcn, MnUserParameterState(par, cov), MnStrategy(stra)), fMinimizer(SimplexMinimizer()) {}

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

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

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

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

   ~MnSimplex() {}

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

private:

   SimplexMinimizer fMinimizer;

private:

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

  }  // namespace Minuit2

}  // namespace ROOT

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