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

Stores all required information for the ECLChargedPIDMVA for a phasespace category. More...

#include <ECLChargedPIDMVAWeights.h>

Inheritance diagram for ECLChargedPIDPhasespaceCategory:
Collaboration diagram for ECLChargedPIDPhasespaceCategory:

Public Types

enum class  MVAResponseTransformMode : unsigned int {
  c_LogTransform = 0 ,
  c_LogTransformSingle = 1 ,
  c_GaussianTransform = 2 ,
  c_DecorrelationTransform = 3 ,
  c_DirectMVAResponse = 4 ,
  c_LogMVAResponse = 5
}
 Enum of implemented transformations which can be applied to the MVA response. More...
 

Public Member Functions

 ECLChargedPIDPhasespaceCategory ()
 Default constructor, necessary for ROOT to stream the object.
 
 ECLChargedPIDPhasespaceCategory (const std::string weightfilePath, const MVAResponseTransformMode &mvaResponeTransformMode, const std::unordered_map< unsigned int, unsigned int > &mvaIndexForHypothesis)
 Useful constructor. More...
 
 ~ECLChargedPIDPhasespaceCategory ()
 Destructor.
 
const std::string getSerialisedWeight () const
 Getter for serialised weightfile.
 
MVAResponseTransformMode getTransformMode () const
 Getter for the MVA transform mode.
 
const TF1 * getPDF (const unsigned int iMVAResponse, const unsigned int hypoPDG) const
 Getter for pdfs. More...
 
const TH1F * getCDF (const unsigned int iMVAResponse, const int hypoPDG) const
 Gets the cdf for the hypothesis pdg for a given response value. More...
 
const std::vector< float > * getDecorrelationMatrix (const int hypoPDG) const
 Gets the decorrelation matrix for a given particle hypothesis. More...
 
void setCDFs (std::vector< std::unordered_map< unsigned int, TH1F >> cdfs)
 Set the cdfs. More...
 
void setPDFs (std::vector< std::unordered_map< unsigned int, TF1 >> &pdfs)
 Set the pdfs. More...
 
void setDecorrelationMatrixMap (std::unordered_map< unsigned int, std::vector< float >> decorrelationMatrices)
 Set the decorrelation matrices. More...
 
void setlogTransformOffset (const float &offset)
 Set the offset used in the log transformation to be consistent with the offset used when generating the p.d.f.s.
 
float getLogTransformOffset () const
 Getter for the log transform offset.
 
void setTemperature (const float &temperature)
 Set the temperature parameter used to calibrate the MVA.
 
float getTemperature () const
 Getter for the temperature.
 
void setMaxPossibleResponseValue (const float &offset)
 Set the max possible response value, used in log transformation of the responses.
 
float getMaxPossibleResponseValue () const
 Get the max possible response value, used in log transformation of the responses.
 
unsigned int getMVAIndexForHypothesis (const unsigned int hypoPDG) const
 Maps a charged stable pdg code to an index of the MVA response. More...
 

Private Member Functions

 ClassDef (ECLChargedPIDPhasespaceCategory, 1)
 ClassDef.
 

Private Attributes

TParameter< float > m_log_transform_offset
 Small offset to avoid mva response values of 1.0 being log transformed to NaN.
 
TParameter< float > m_max_possible_response_value
 Max possible value of the mva response. More...
 
TParameter< float > m_temperature
 calibration factor for MVA responses. More...
 
std::string m_weight
 Serialsed MVA weightfile.
 
MVAResponseTransformMode m_mvaResponseTransformMode
 Stores which transformation mode to apply to the mva responses.
 
std::vector< std::unordered_map< unsigned int, TF1 > > m_pdfs
 A vector of unodered maps. More...
 
std::unordered_map< unsigned int, unsigned int > m_mvaIndexForHypothesis
 Unordered map of abs(pdg_code) for the 6 charged stable hypotheses to index of the MVA response vector. More...
 
std::vector< std::unordered_map< unsigned int, TH1F > > m_cdfs
 CDFs for each mva return value for each hypothesis. More...
 
std::unordered_map< unsigned int, std::vector< float > > m_decorrelationMatrices
 Decorrelation matrices. More...
 

Detailed Description

Stores all required information for the ECLChargedPIDMVA for a phasespace category.

This includes:

  • MVA weightfiles for multiclass MVA.
  • MVAResponseTransform mode detailing which transformations will be applied to the MVA response.
  • unordered_map mapping a particle hypothesis to the output index of a MVA.
  • (Optional) TF1 p.d.fs for each charged particle hypothesis for each mva output variable.
  • (Optional) TH1F for each charged particle hypothesis for each mva output variable for gaussianisation.
  • (Optional) vector of floats (flattened square matrix) for potential linear decorrelation of the gaussian transformed mva response variables.

Definition at line 132 of file ECLChargedPIDMVAWeights.h.

Member Enumeration Documentation

◆ MVAResponseTransformMode

enum MVAResponseTransformMode : unsigned int
strong

Enum of implemented transformations which can be applied to the MVA response.

Enumerator
c_LogTransform 

Log transform the mva responses.

And take the likelihood as the product of likelihoods from all mva responses.

c_LogTransformSingle 

Log transform the mva responses.

Take the likelihood from only the mva response for the hypothesis.

c_GaussianTransform 

Gaussian transform of the log transformed mva response.

c_DecorrelationTransform 

Decorrelation transform of the gaussian transformed mva responses.

c_DirectMVAResponse 

Directly take the MVA response as the logL, useful if we train neural nets to learn the logL.

c_LogMVAResponse 

Take the log of the MVA response.

Essentially undoes the softmax function.

Definition at line 136 of file ECLChargedPIDMVAWeights.h.

Constructor & Destructor Documentation

◆ ECLChargedPIDPhasespaceCategory()

ECLChargedPIDPhasespaceCategory ( const std::string  weightfilePath,
const MVAResponseTransformMode mvaResponeTransformMode,
const std::unordered_map< unsigned int, unsigned int > &  mvaIndexForHypothesis 
)
inline

Useful constructor.

Parameters
weightfilePathpath to the MVA weightfile for this phasespace category.
mvaResponeTransformModemva response transform mode booked for this phasespace.
mvaIndexForHypothesisunordered_map mapping hypothesis to index of mva response. Useful if we exclude a class from the MVA training but want to use the likelihood of a different particle. For example using the proton pdf for a deuteron.

Definition at line 167 of file ECLChargedPIDMVAWeights.h.

Member Function Documentation

◆ getCDF()

const TH1F* getCDF ( const unsigned int  iMVAResponse,
const int  hypoPDG 
) const
inline

Gets the cdf for the hypothesis pdg for a given response value.

Parameters
iMVAResponseindex of MVA response.
hypoPDGhypothesis pdg.

Definition at line 224 of file ECLChargedPIDMVAWeights.h.

◆ getDecorrelationMatrix()

const std::vector<float>* getDecorrelationMatrix ( const int  hypoPDG) const
inline

Gets the decorrelation matrix for a given particle hypothesis.

Parameters
hypoPDGhypothesis pdg.

Definition at line 233 of file ECLChargedPIDMVAWeights.h.

◆ getMVAIndexForHypothesis()

unsigned int getMVAIndexForHypothesis ( const unsigned int  hypoPDG) const
inline

Maps a charged stable pdg code to an index of the MVA response.

In general this is a one-to-one mapping however in cases where we do not include all six stable charged particles in the MVA training we may have a many-to-one mapping. For example if we take the proton response value also for deuterons.

Definition at line 315 of file ECLChargedPIDMVAWeights.h.

◆ getPDF()

const TF1* getPDF ( const unsigned int  iMVAResponse,
const unsigned int  hypoPDG 
) const
inline

Getter for pdfs.

Parameters
iMVAResponseindex of MVA response.
hypoPDGhypothesis pdg.

Definition at line 214 of file ECLChargedPIDMVAWeights.h.

◆ setCDFs()

void setCDFs ( std::vector< std::unordered_map< unsigned int, TH1F >>  cdfs)
inline

Set the cdfs.

Parameters
cdfsvector of map of cdfs to be stored in the payload.

Definition at line 242 of file ECLChargedPIDMVAWeights.h.

◆ setDecorrelationMatrixMap()

void setDecorrelationMatrixMap ( std::unordered_map< unsigned int, std::vector< float >>  decorrelationMatrices)
inline

Set the decorrelation matrices.

Parameters
decorrelationMatricesmap of decorrelation matrices to be stored in the payload.

Definition at line 256 of file ECLChargedPIDMVAWeights.h.

◆ setPDFs()

void setPDFs ( std::vector< std::unordered_map< unsigned int, TF1 >> &  pdfs)
inline

Set the pdfs.

Parameters
pdfsvector of map of pdfs to be stored in the payload.

Definition at line 249 of file ECLChargedPIDMVAWeights.h.

Member Data Documentation

◆ m_cdfs

std::vector<std::unordered_map<unsigned int, TH1F> > m_cdfs
private

CDFs for each mva return value for each hypothesis.

The N vector elements correspond to the N MVA return values. The unordered map maps the hypothesis pdg values to their matching TH1F cdfs which can be used for a gaussianisation.

Definition at line 353 of file ECLChargedPIDMVAWeights.h.

◆ m_decorrelationMatrices

std::unordered_map<unsigned int, std::vector<float> > m_decorrelationMatrices
private

Decorrelation matrices.

To be used (optionally) afer gaussianisation. The unordered map maps the hypothesis pdg values to their matching linearised decorrelation matrix.

Definition at line 359 of file ECLChargedPIDMVAWeights.h.

◆ m_max_possible_response_value

TParameter<float> m_max_possible_response_value
private

Max possible value of the mva response.

Used in the log transformation.

Definition at line 323 of file ECLChargedPIDMVAWeights.h.

◆ m_mvaIndexForHypothesis

std::unordered_map<unsigned int, unsigned int> m_mvaIndexForHypothesis
private

Unordered map of abs(pdg_code) for the 6 charged stable hypotheses to index of the MVA response vector.

Needed if we do not train with all 6 species to map several to the same MVA response value.

Definition at line 346 of file ECLChargedPIDMVAWeights.h.

◆ m_pdfs

std::vector<std::unordered_map<unsigned int, TF1> > m_pdfs
private

A vector of unodered maps.

The vector corresponds to the return values of the MVA, one for each class correspondonding to charged stable particles considered by the MVA. In general this is the full six charged stable particles {e, mu, pi, K, p, d}. The unordered map maps the hypothesis pdg values to their matching TF1 pdfs from which the liklihood will be taken.

Definition at line 340 of file ECLChargedPIDMVAWeights.h.

◆ m_temperature

TParameter<float> m_temperature
private

calibration factor for MVA responses.

Follows arXiv:1706.04599

Definition at line 324 of file ECLChargedPIDMVAWeights.h.


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