laura is hosted by Hepforge, IPPP Durham
Laura++  3.6.0
A maximum likelihood fitting package for performing Dalitz-plot analysis.
LauExponentialPdf.cc
Go to the documentation of this file.
1 
2 /*
3 Copyright 2011 University of Warwick
4 
5 Licensed under the Apache License, Version 2.0 (the "License");
6 you may not use this file except in compliance with the License.
7 You may obtain a copy of the License at
8 
9  http://www.apache.org/licenses/LICENSE-2.0
10 
11 Unless required by applicable law or agreed to in writing, software
12 distributed under the License is distributed on an "AS IS" BASIS,
13 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 See the License for the specific language governing permissions and
15 limitations under the License.
16 */
17 
18 /*
19 Laura++ package authors:
20 John Back
21 Paul Harrison
22 Thomas Latham
23 */
24 
29 #include <iostream>
30 #include <vector>
31 using std::cerr;
32 using std::cout;
33 using std::endl;
34 
35 #include "LauConstants.hh"
36 #include "LauExponentialPdf.hh"
37 
38 #include "TMath.h"
39 #include "TSystem.h"
40 
41 LauExponentialPdf::LauExponentialPdf( const TString& theVarName,
42  const std::vector<LauAbsRValue*>& params,
43  Double_t minAbscissa,
44  Double_t maxAbscissa ) :
45  LauAbsPdf( theVarName, params, minAbscissa, maxAbscissa ),
46  slope_( 0 )
47 {
48  // Constructor for the Exponential PDF.
49  //
50  // The parameter in param is the slope of the exponential ie exp(slope*x).
51  // The last two arguments specify the range in which the PDF is defined, and the PDF
52  // will be normalised w.r.t. these limits.
53 
54  slope_ = this->findParameter( "slope" );
55 
56  if ( ( this->nParameters() != 1 ) || ( slope_ == 0 ) ) {
57  cerr << "ERROR in LauExponentialPdf constructor: LauExponentialPdf requires 1 parameter: \"slope\"."
58  << endl;
59  gSystem->Exit( EXIT_FAILURE );
60  }
61 
62  // Cache the normalisation factor
63  this->calcNorm();
64 }
65 
67 {
68  // Destructor
69 }
70 
72 {
73  // Check that the given abscissa is within the allowed range
74  if ( ! this->checkRange( abscissas ) ) {
75  gSystem->Exit( EXIT_FAILURE );
76  }
77 
78  // Get our abscissa
79  Double_t abscissa = abscissas[0];
80 
81  // Get the up to date parameter values
82  Double_t slope = slope_->unblindValue();
83 
84  // Calculate the value of the Exponential for the given value of the abscissa.
85 
86  Double_t exponent( 0.0 );
87  if ( slope != 0 ) {
88  exponent = slope * abscissa;
89  }
90 
91  Double_t value = TMath::Exp( exponent );
92  this->setUnNormPDFVal( value );
93 
94  // if the parameters are floating then we
95  // need to recalculate the normalisation
96  if ( ! this->cachePDF() && ! this->withinNormCalc() && ! this->withinGeneration() ) {
97  this->calcNorm();
98  }
99 }
100 
102 {
103  // Get the up to date parameter values
104  Double_t slope = slope_->unblindValue();
105 
106  // Calculate the normalisation of the exponential and cache it.
107  Double_t norm( 0.0 );
108 
109  if ( slope != 0 ) {
110  norm = ( 1 / slope ) * ( TMath::Exp( slope * this->getMaxAbscissa() ) -
111  TMath::Exp( slope * this->getMinAbscissa() ) );
112  }
113 
114  this->setNorm( norm );
115 }
116 
117 void LauExponentialPdf::calcPDFHeight( const LauKinematics* /*kinematics*/ )
118 {
119  if ( this->heightUpToDate() ) {
120  return;
121  }
122 
123  // Get the up to date parameter values
124  Double_t slope = slope_->unblindValue();
125 
126  LauAbscissas maxPoint( 1 );
127  maxPoint[0] = 0;
128 
129  // Calculate the PDF height for the Exponential function.
130  if ( slope > 0 ) {
131  maxPoint[0] = this->getMaxAbscissa();
132  } else if ( slope < 0 ) {
133  maxPoint[0] = this->getMinAbscissa();
134  }
135  this->calcLikelihoodInfo( maxPoint );
136 
137  Double_t height = this->getUnNormLikelihood();
138  this->setMaxHeight( height );
139 }
virtual void calcPDFHeight(const LauKinematics *kinematics)
Calculate the PDF height.
virtual Double_t getMaxAbscissa() const
Retrieve the maximum value of the (primary) abscissa.
Definition: LauAbsPdf.hh:141
virtual ~LauExponentialPdf()
Destructor.
Double_t value() const
The value of the parameter.
virtual Double_t getMinAbscissa() const
Retrieve the minimum value of the (primary) abscissa.
Definition: LauAbsPdf.hh:135
virtual Bool_t cachePDF() const
Check if the PDF is to be cached.
Definition: LauAbsPdf.hh:299
std::vector< Double_t > LauAbscissas
The type used for containing multiple abscissa values.
Definition: LauAbsPdf.hh:58
virtual LauAbsRValue * findParameter(const TString &parName)
Retrieve the specified parameter.
Definition: LauAbsPdf.cc:431
virtual void calcNorm()
Calculate the normalisation.
virtual Bool_t withinNormCalc() const
Check whether the calcNorm method is running.
Definition: LauAbsPdf.hh:448
virtual UInt_t nParameters() const
Retrieve the number of PDF parameters.
Definition: LauAbsPdf.hh:109
virtual void setNorm(Double_t norm)
Set the normalisation factor.
Definition: LauAbsPdf.hh:348
virtual Double_t unblindValue() const =0
The unblinded value of the parameter.
LauAbsRValue * slope_
Exponential slope ie exp(slope*x)
virtual void setUnNormPDFVal(Double_t unNormPDFVal)
Set the unnormalised likelihood.
Definition: LauAbsPdf.hh:394
virtual void calcLikelihoodInfo(const LauAbscissas &abscissas)
Calculate the likelihood (and intermediate info) for a given abscissa.
Class for defining the abstract interface for PDF classes.
Definition: LauAbsPdf.hh:54
virtual Bool_t withinGeneration() const
Check whether the generate method is running.
Definition: LauAbsPdf.hh:460
File containing LauConstants namespace.
File containing declaration of LauExponentialPdf class.
virtual void setMaxHeight(Double_t maxHeight)
Set the maximum height.
Definition: LauAbsPdf.hh:354
Class for calculating 3-body kinematic quantities.
virtual Double_t getUnNormLikelihood() const
Retrieve the unnormalised likelihood value.
Definition: LauAbsPdf.hh:218
virtual Bool_t heightUpToDate() const
Check if the maximum height of the PDF is up to date.
Definition: LauAbsPdf.hh:287
virtual Bool_t checkRange(const LauAbscissas &abscissas) const
Check that all abscissas are within their allowed ranges.
Definition: LauAbsPdf.cc:243
LauExponentialPdf(const TString &theVarName, const std::vector< LauAbsRValue * > &params, Double_t minAbscissa, Double_t maxAbscissa)
Constructor.