Belle II Software  release-08-01-10
KLMLikelihoodParameters Class Reference

Database object used to store the parameters for KLM likelihood computation. More...

#include <KLMLikelihoodParameters.h>

Inheritance diagram for KLMLikelihoodParameters:
Collaboration diagram for KLMLikelihoodParameters:

Public Member Functions

 KLMLikelihoodParameters ()
 Constructor.
 
 ~KLMLikelihoodParameters ()
 Destructor.
 
void setLongitudinalPDF (int hypothesis, int outcome, int lastLayer, const std::vector< double > &params)
 Set the longitudinal probability density function for specific hypothesis, outcome and last layer. More...
 
void setTransversePDF (int hypothesis, int detector, int degreesOfFreedom, const std::vector< double > &params)
 Set the transverse probability density function for specific hypothesis, detector and degrees of freedom. More...
 
void setTransverseThreshold (int hypothesis, int detector, int degreesOfFreedom, const double threshold)
 Set the transverse probability density function (analytical): threshold for specific hypothesis, detector and degrees of freedom. More...
 
void setTransverseScaleX (int hypothesis, int detector, int degreesOfFreedom, const double scaleX)
 Set the transverse probability density function (analytical): horizontal scale for specific hypothesis, detector and degrees of freedom. More...
 
void setTransverseScaleY (int hypothesis, int detector, int degreesOfFreedom, const double scaleY)
 Set the transverse probability density function (analytical): vertical scale for specific hypothesis, detector and degrees of freedom. More...
 
const std::vector< double > & getLongitudinalPDF (int hypothesis, int outcome, int lastLayer) const
 Get the longitudinal probability density function for specific hypothesis, outcome and last layer. More...
 
const std::vector< double > & getTransversePDF (int hypothesis, int detector, int degreesOfFreedom) const
 Get the transverse probability density function for specific hypothesis, detector and degrees of freedom. More...
 
double getTransverseThreshold (int hypothesis, int detector, int degreesOfFreedom) const
 Get the transverse probability density function (analytical): threshold for specific hypothesis, detector and degrees of freedom. More...
 
double getTransverseScaleX (int hypothesis, int detector, int degreesOfFreedom) const
 Get the transverse probability density function (analytical): horizontal scale for specific hypothesis, detector and degrees of freedom. More...
 
double getTransverseScaleY (int hypothesis, int detector, int degreesOfFreedom) const
 Get the transverse probability density function (analytical): vertical scale for specific hypothesis, detector and degrees of freedom. More...
 

Private Member Functions

void setLongitudinalPDF (const int id, const std::vector< double > &params)
 Set the longitudinal probability density function for a given identifier. More...
 
void setTransversePDF (const int id, const std::vector< double > &params)
 Set the transverse probability density function for a given identifier. More...
 
void setTransverseThreshold (const int id, const double threshold)
 Set the transverse probability density function (analytical): threshold for a given identifier. More...
 
void setTransverseScaleX (const int id, const double scaleX)
 Set the transverse probability density function (analytical): horizontal scale for a given identifier. More...
 
void setTransverseScaleY (const int id, const double scaleY)
 Set the transverse probability density function (analytical): vertical scale for a given identifier. More...
 
const std::vector< double > & getLongitudinalPDF (const int id) const
 Get the longitudinal probability density function for a given identifier. More...
 
const std::vector< double > & getTransversePDF (const int id) const
 Get the transverse probability density function for a given identifier. More...
 
double getTransverseThreshold (const int id) const
 Get the transverse probability density function (analytical): threshold for a given identifier. More...
 
double getTransverseScaleX (const int id) const
 Get the transverse probability density function (analytical): horizontal scale for a given identifier. More...
 
double getTransverseScaleY (const int id) const
 Get the transverse probability density function (analytical): vertical scale for a given identifier. More...
 
 ClassDef (KLMLikelihoodParameters, 1)
 Class version.
 

Private Attributes

std::map< int, std::vector< double > > m_LongitudinalPDF
 Longitudinal probability density function.
 
std::map< int, std::vector< double > > m_TransversePDF
 Transverse probability density function.
 
std::map< int, double > m_TransverseThreshold
 Transverse probability density function (analytical): threshold.
 
std::map< int, double > m_TransverseScaleX
 Transverse probability density function (analytical): horizontal scale.
 
std::map< int, double > m_TransverseScaleY
 Transverse probability density function (analytical): vertical scale.
 

Detailed Description

Database object used to store the parameters for KLM likelihood computation.

Definition at line 28 of file KLMLikelihoodParameters.h.

Member Function Documentation

◆ getLongitudinalPDF() [1/2]

const std::vector< double > & getLongitudinalPDF ( const int  id) const
private

Get the longitudinal probability density function for a given identifier.

Parameters
[in]idLongitudinal identifier.

Definition at line 17 of file KLMLikelihoodParameters.cc.

18 {
19  std::map<int, std::vector<double>>::const_iterator it = m_LongitudinalPDF.find(id);
20  if (it != m_LongitudinalPDF.end()) {
21  return it->second;
22  } else {
23  B2FATAL("Longitudinal for KLMLikelihoodParameters not found!");
24  }
25 }
std::map< int, std::vector< double > > m_LongitudinalPDF
Longitudinal probability density function.

◆ getLongitudinalPDF() [2/2]

const std::vector<double>& getLongitudinalPDF ( int  hypothesis,
int  outcome,
int  lastLayer 
) const
inline

Get the longitudinal probability density function for specific hypothesis, outcome and last layer.

Parameters
[in]hypothesisHypothesis number.
[in]outcomeTrack extrapolation outcome.
[in]lastLayerLast layer crossed during the extrapolation.

Definition at line 117 of file KLMLikelihoodParameters.h.

118  {
119  const int id = MuidElementNumbers::getLongitudinalID(hypothesis, outcome, lastLayer);
120  return getLongitudinalPDF(id);
121  }
const std::vector< double > & getLongitudinalPDF(int hypothesis, int outcome, int lastLayer) const
Get the longitudinal probability density function for specific hypothesis, outcome and last layer.
static int getLongitudinalID(int hypothesis, int outcome, int lastLayer)
Get the unique longitudinal identifier for given hypothesis, outcome and last layer crossed.

◆ getTransversePDF() [1/2]

const std::vector< double > & getTransversePDF ( const int  id) const
private

Get the transverse probability density function for a given identifier.

Parameters
[in]idTransverse identifier.

Definition at line 27 of file KLMLikelihoodParameters.cc.

◆ getTransversePDF() [2/2]

const std::vector<double>& getTransversePDF ( int  hypothesis,
int  detector,
int  degreesOfFreedom 
) const
inline

Get the transverse probability density function for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.

Definition at line 129 of file KLMLikelihoodParameters.h.

◆ getTransverseScaleX() [1/2]

double getTransverseScaleX ( const int  id) const
private

Get the transverse probability density function (analytical): horizontal scale for a given identifier.

Parameters
[in]idTransverse identifier.

Definition at line 47 of file KLMLikelihoodParameters.cc.

◆ getTransverseScaleX() [2/2]

double getTransverseScaleX ( int  hypothesis,
int  detector,
int  degreesOfFreedom 
) const
inline

Get the transverse probability density function (analytical): horizontal scale for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.

Definition at line 153 of file KLMLikelihoodParameters.h.

◆ getTransverseScaleY() [1/2]

double getTransverseScaleY ( const int  id) const
private

Get the transverse probability density function (analytical): vertical scale for a given identifier.

Parameters
[in]idTransverse identifier.

Definition at line 57 of file KLMLikelihoodParameters.cc.

◆ getTransverseScaleY() [2/2]

double getTransverseScaleY ( int  hypothesis,
int  detector,
int  degreesOfFreedom 
) const
inline

Get the transverse probability density function (analytical): vertical scale for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.

Definition at line 165 of file KLMLikelihoodParameters.h.

◆ getTransverseThreshold() [1/2]

double getTransverseThreshold ( const int  id) const
private

Get the transverse probability density function (analytical): threshold for a given identifier.

Parameters
[in]idTransverse identifier.

Definition at line 37 of file KLMLikelihoodParameters.cc.

◆ getTransverseThreshold() [2/2]

double getTransverseThreshold ( int  hypothesis,
int  detector,
int  degreesOfFreedom 
) const
inline

Get the transverse probability density function (analytical): threshold for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.

Definition at line 141 of file KLMLikelihoodParameters.h.

◆ setLongitudinalPDF() [1/2]

void setLongitudinalPDF ( const int  id,
const std::vector< double > &  params 
)
inlineprivate

Set the longitudinal probability density function for a given identifier.

Parameters
[in]idLongitudinal identifier.
[in]paramsLikelihood parameters.

Definition at line 178 of file KLMLikelihoodParameters.h.

◆ setLongitudinalPDF() [2/2]

void setLongitudinalPDF ( int  hypothesis,
int  outcome,
int  lastLayer,
const std::vector< double > &  params 
)
inline

Set the longitudinal probability density function for specific hypothesis, outcome and last layer.

Parameters
[in]hypothesisHypothesis number.
[in]outcomeTrack extrapolation outcome.
[in]lastLayerLast layer crossed during the extrapolation.
[in]paramsLikelihood parameters.

Definition at line 53 of file KLMLikelihoodParameters.h.

◆ setTransversePDF() [1/2]

void setTransversePDF ( const int  id,
const std::vector< double > &  params 
)
inlineprivate

Set the transverse probability density function for a given identifier.

Parameters
[in]idTransverse identifier.
[in]paramsLikelihood parameters.

Definition at line 188 of file KLMLikelihoodParameters.h.

◆ setTransversePDF() [2/2]

void setTransversePDF ( int  hypothesis,
int  detector,
int  degreesOfFreedom,
const std::vector< double > &  params 
)
inline

Set the transverse probability density function for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.
[in]paramsLikelihood parameters.

Definition at line 66 of file KLMLikelihoodParameters.h.

◆ setTransverseScaleX() [1/2]

void setTransverseScaleX ( const int  id,
const double  scaleX 
)
inlineprivate

Set the transverse probability density function (analytical): horizontal scale for a given identifier.

Parameters
[in]idTransverse identifier.
[in]scaleXHorizontal scale.

Definition at line 208 of file KLMLikelihoodParameters.h.

◆ setTransverseScaleX() [2/2]

void setTransverseScaleX ( int  hypothesis,
int  detector,
int  degreesOfFreedom,
const double  scaleX 
)
inline

Set the transverse probability density function (analytical): horizontal scale for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.
[in]scaleXHorizontal scale.

Definition at line 92 of file KLMLikelihoodParameters.h.

◆ setTransverseScaleY() [1/2]

void setTransverseScaleY ( const int  id,
const double  scaleY 
)
inlineprivate

Set the transverse probability density function (analytical): vertical scale for a given identifier.

Parameters
[in]idTransverse identifier.
[in]scaleYVertical scale.

Definition at line 218 of file KLMLikelihoodParameters.h.

◆ setTransverseScaleY() [2/2]

void setTransverseScaleY ( int  hypothesis,
int  detector,
int  degreesOfFreedom,
const double  scaleY 
)
inline

Set the transverse probability density function (analytical): vertical scale for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.
[in]scaleYVertical scale.

Definition at line 105 of file KLMLikelihoodParameters.h.

◆ setTransverseThreshold() [1/2]

void setTransverseThreshold ( const int  id,
const double  threshold 
)
inlineprivate

Set the transverse probability density function (analytical): threshold for a given identifier.

Parameters
[in]idTransverse identifier.
[in]thresholdTransverse threshold.

Definition at line 198 of file KLMLikelihoodParameters.h.

◆ setTransverseThreshold() [2/2]

void setTransverseThreshold ( int  hypothesis,
int  detector,
int  degreesOfFreedom,
const double  threshold 
)
inline

Set the transverse probability density function (analytical): threshold for specific hypothesis, detector and degrees of freedom.

Parameters
[in]hypothesisHypothesis number.
[in]detectorDetector number.
[in]degreesOfFreedomNumber of degrees of freedom.
[in]thresholdTransverse threshold.

Definition at line 79 of file KLMLikelihoodParameters.h.


The documentation for this class was generated from the following files: