AmpTools
MIFunctionContribution.h
Go to the documentation of this file.
1 #if !defined(MINUITINTERFACE_MIFUNCTIONCONTRIBUTION_H)
2 #define MINUITINTERFACE_MIFUNCTIONCONTRIBUTION_H
3 
4 // This file is a part of MinuitInterface - a front end for the Minuit minimization
5 // package (Minuit itself was authored by Fred James, of CERN)
6 //
7 //
8 // Copyright Cornell University 1993, 1996, All Rights Reserved.
9 //
10 // This software written by Lawrence Gibbons, Cornell University.
11 //
12 // Redistribution and use in source and binary forms, with or without
13 // modification, are permitted provided that the following conditions
14 // are met:
15 // 1. Redistributions of source code must retain the above copyright
16 // notice and author attribution, this list of conditions and the
17 // following disclaimer.
18 // 2. Redistributions in binary form must reproduce the above copyright
19 // notice and author attribution, this list of conditions and the
20 // following disclaimer in the documentation and/or other materials
21 // provided with the distribution.
22 // 3. Neither the name of the University nor the names of its contributors
23 // may be used to endorse or promote products derived from this software
24 // without specific prior written permission.
25 //
26 // Creation of derivative forms of this software for commercial
27 // utilization may be subject to restriction; written permission may be
28 // obtained from Cornell University.
29 //
30 // CORNELL MAKES NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED. By way
31 // of example, but not limitation, CORNELL MAKES NO REPRESENTATIONS OR
32 // WARRANTIES OF MERCANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT
33 // THE USE OF THIS SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY PATENTS,
34 // COPYRIGHTS, TRADEMARKS, OR OTHER RIGHTS. Cornell University shall not be
35 // held liable for any liability with respect to any claim by the user or any
36 // other party arising from use of the program.
37 //
38 
41 
43 class MinuitParameter;
44 
46 {
47 public :
48 
49  // this flag is
50  static const double kUnknownDerivative;
51 
53  virtual ~MIFunctionContribution();
54 
55  virtual double operator()() = 0;
56 
57  // function contributors can override this method if they wish to provide
58  // derivatives of the function with respect to fit parameters
59  virtual double derivative( const MinuitParameter& par );
60 
61  virtual void update( const MISubject* );
62  virtual double contribution();
63 
64  // turn off or turn on whether this function contributes. Check status.
65  void stopContributing();
66  void restartContributing();
67  bool contributing() const {return m_contributing;}
68 
69 private:
70 
71  MinuitMinimizationManager* m_manager;
72 
73  bool m_functionEvaluated;
74  double m_contribution;
75  bool m_contributing;
76 
77 };
78 
79 #endif
virtual void update(const MISubject *)
virtual double derivative(const MinuitParameter &par)
static const double kUnknownDerivative
virtual double operator()()=0
MIFunctionContribution(MinuitMinimizationManager *)