// @(#)root/tmva $Id$ 
// Author: Peter Speckmayer

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : MinuitWrapper                                                         *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *       Wrapper around MINUIT                                                    *
 *                                                                                *
 * Authors (alphabetical):                                                        *
 *      Peter Speckmayer <peter.speckmayer@cern.ch> - CERN, Switzerland           *
 *                                                                                *
 * Copyright (c) 2005:                                                            *
 *      CERN, Switzerland                                                         * 
 *      MPI-K Heidelberg, Germany                                                 * 
 *                                                                                *
 * Redistribution and use in source and binary forms, with or without             *
 * modification, are permitted according to the terms listed in LICENSE           *
 * (http://tmva.sourceforge.net/LICENSE)                                          *
 **********************************************************************************/

#ifndef ROOT_TMVA_MinuitWrapper
#define ROOT_TMVA_MinuitWrapper

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// MinuitWrapper                                                        //
//                                                                      //
// Wrapper around MINUIT                                                //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

#ifndef ROOT_TMinuit
#include "TMinuit.h"
#endif
#ifndef ROOT_TMVA_IFitterTarget
#include "TMVA/IFitterTarget.h"
#endif

class TMinuit;

namespace TMVA {

   class IFitterTarget;

   class MinuitWrapper : public TMinuit {
      
   public:
          
      MinuitWrapper( IFitterTarget& target, Int_t maxpar);
      virtual ~MinuitWrapper() {}

      Int_t Eval(Int_t, Double_t*, Double_t&, Double_t*, Int_t);
      void SetFitterTarget( IFitterTarget& target ) { fFitterTarget = target; }

      Int_t ExecuteCommand(const char *command, Double_t *args, Int_t nargs);
      void  Clear(Option_t * = 0);
      Int_t GetStats    (Double_t &amin, Double_t &edm, Double_t &errdef, Int_t &nvpar, Int_t &nparx);
      Int_t GetErrors   (Int_t ipar, Double_t &eplus, Double_t &eminus, Double_t &eparab, Double_t &globcc);
      Int_t SetParameter(Int_t ipar,const char *parname, Double_t value, Double_t verr, Double_t vlow, Double_t vhigh);
      TObject *Clone(char const*) const;
      
   private:
      
      IFitterTarget&        fFitterTarget; // fitter Target
      std::vector<Double_t> fParameters;   // vector holding the current parameters 
      Int_t                 fNumPar;       // number of parameters
      
      ClassDef(MinuitWrapper,0) // Wrapper around TMinuit
   };

} // namespace TMVA

#endif


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