Belle II Software development
VXDMomentumEstimation.h
1/**************************************************************************
2 * basf2 (Belle II Analysis Software Framework) *
3 * Author: The Belle II Collaboration *
4 * *
5 * See git log for contributors and copyright holders. *
6 * This file is licensed under LGPL-3.0, see LICENSE.md. *
7 **************************************************************************/
8
9#pragma once
10#include <tracking/vxdMomentumEstimation/VXDMomentumEstimationTools.h>
11
12
13namespace Belle2 {
26 template <class ClusterType>
28
29 private:
36
37 public:
41 double aE = 1.56173140e+07;
43 double bE = -9.89192780e+03;
45 double cE = 2.42177970e-02;
47 double dE = 2.65702553e-08;
48 };
49
54 double aM = 0;
56 double bM = 0;
58 double cM = 0;
60 double dM = 0;
61 };
62
65 {
66 static VXDMomentumEstimation instance;
67 return instance;
68 }
69
72 double estimateQOverP(const ClusterType& cluster, const ROOT::Math::XYZVector& momentum, const ROOT::Math::XYZVector& position,
73 short charge,
74 const FitParameters& fitParameters, const CorrectionFitParameters& correctionFitParameters) const
75 {
77
78 const double dEdX = tools.getDEDX(cluster, momentum, position, charge);
79 const double momentumEstimation = convertDEDXToMomentum(dEdX, fitParameters, correctionFitParameters);
80 const double QOverP = charge / momentumEstimation;
81
82 return QOverP;
83 }
84
87 double estimateQOverPWithThickness(const ClusterType& cluster, short charge, const FitParameters& fitParameters,
88 const CorrectionFitParameters& correctionFitParameters) const
89 {
91
92 const double dEdX = tools.getDEDXWithThickness(cluster);
93 const double momentumEstimation = convertDEDXToMomentum(dEdX, fitParameters, correctionFitParameters);
94 const double QOverP = charge / momentumEstimation;
95
96 return QOverP;
97 }
98
101 double convertDEDXToMomentum(double dEdX, const FitParameters& fitParameters,
102 const CorrectionFitParameters& correctionFitParameters) const
103 {
104 const double firstPart = fitParameters.aE / (dEdX - fitParameters.bE) / (dEdX - fitParameters.bE);
105 const double lastPart = fitParameters.cE + fitParameters.dE * dEdX;
106 const double estimation = firstPart + lastPart;
107
108 const double quadPart = correctionFitParameters.aM * estimation * estimation;
109 const double linearPart = correctionFitParameters.bM * estimation;
110 const double constantPart = correctionFitParameters.cM;
111 const double cubicPart = correctionFitParameters.dM * estimation * estimation * estimation;
112 const double mediumCorrection = cubicPart + quadPart + linearPart + constantPart;
113
114 const double estimationWithMediumCalibration = estimation - mediumCorrection;
115 return estimationWithMediumCalibration;
116 }
117
118 };
120}
Tools needed for the VXD momentum estimation to, e.g.
static const VXDMomentumEstimationTools & getInstance()
Use this class as singleton.
double getDEDX(const ClusterType &cluster, const ROOT::Math::XYZVector &momentum, const ROOT::Math::XYZVector &position, short charge) const
Main function: return dEdX for a cluster and the given momentum, position and charge seeds.
double getDEDXWithThickness(const ClusterType &cluster) const
Return dEdX but not with dX = path length but with dX = thickness of cluster.
Class doing the momentum estimation from dEdX for SVDClusters and PXDClusters.
VXDMomentumEstimation(const VXDMomentumEstimation &)
Do not copy or create.
double estimateQOverP(const ClusterType &cluster, const ROOT::Math::XYZVector &momentum, const ROOT::Math::XYZVector &position, short charge, const FitParameters &fitParameters, const CorrectionFitParameters &correctionFitParameters) const
Main function: Estimate p over q for the given cluster and the path length calculated using the given...
VXDMomentumEstimation & operator=(const VXDMomentumEstimation &)
Do not copy or create.
double estimateQOverPWithThickness(const ClusterType &cluster, short charge, const FitParameters &fitParameters, const CorrectionFitParameters &correctionFitParameters) const
Main function: Estimate p over q for the given cluster and the thickness of the cluster with the fit ...
double convertDEDXToMomentum(double dEdX, const FitParameters &fitParameters, const CorrectionFitParameters &correctionFitParameters) const
After calculating dEdX we need to map this to p using a predefined function and parameters that were ...
static const VXDMomentumEstimation & getInstance()
Use this class as a singleton.
VXDMomentumEstimation()
Do not copy or create.
Abstract base class for different kinds of events.
Struct holding the parameters of the correction function to map them median of the estimation functio...
Struct holding the parameters of the estimation function which maps dEdX to p.