Logo ROOT   6.30.04
Reference Guide
 All Namespaces Files Pages
HessianGradientCalculator.h
Go to the documentation of this file.
1 // @(#)root/minuit2:$Id$
2 // Authors: M. Winkler, F. James, L. Moneta, A. Zsenei 2003-2005
3 
4 /**********************************************************************
5  * *
6  * Copyright (c) 2005 LCG ROOT Math team, CERN/PH-SFT *
7  * *
8  **********************************************************************/
9 
10 #ifndef ROOT_Minuit2_HessianGradientCalculator
11 #define ROOT_Minuit2_HessianGradientCalculator
12 
14 #include "Minuit2/MnMatrix.h"
15 #include <utility>
16 
17 namespace ROOT {
18 
19  namespace Minuit2 {
20 
21 
22 
23 class MnFcn;
24 class MnUserTransformation;
25 class MnMachinePrecision;
26 class MnStrategy;
27 
28 /**
29  HessianGradientCalculator: class to calculate Gradient for Hessian
30  */
31 
32 class HessianGradientCalculator : public GradientCalculator {
33 
34 public:
35 
36  HessianGradientCalculator(const MnFcn& fcn, const MnUserTransformation& par,
37  const MnStrategy& stra) :
38  fFcn(fcn), fTransformation(par), fStrategy(stra) {}
39 
40  virtual ~HessianGradientCalculator() {}
41 
42  virtual FunctionGradient operator()(const MinimumParameters&) const;
43 
44  virtual FunctionGradient operator()(const MinimumParameters&,
45  const FunctionGradient&) const;
46 
47  std::pair<FunctionGradient, MnAlgebraicVector> DeltaGradient(const MinimumParameters&, const FunctionGradient&) const;
48 
49  const MnFcn& Fcn() const {return fFcn;}
50  const MnUserTransformation& Trafo() const {return fTransformation;}
51  const MnMachinePrecision& Precision() const;
52  const MnStrategy& Strategy() const {return fStrategy;}
53 
54  unsigned int Ncycle() const;
55  double StepTolerance() const;
56  double GradTolerance() const;
57 
58 private:
59 
60  const MnFcn& fFcn;
61  const MnUserTransformation& fTransformation;
62  const MnStrategy& fStrategy;
63 };
64 
65  } // namespace Minuit2
66 
67 } // namespace ROOT
68 
69 #endif // ROOT_Minuit2_HessianGradientCalculator