-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCalibData.h
271 lines (240 loc) · 10.5 KB
/
CalibData.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
//
// $Id: CalibData.h,v 1.93 2013/05/08 14:38:26 kirschen Exp $
//
#ifndef CalibData_h
#define CalibData_h
#include <iostream>
#include <vector>
#include <cmath>
#include <cassert>
class Parameters;
//! \brief Type of data
//!
//! \sa TAbstractData
enum DataType {Default, TrackTower, GammaJet, TrackCluster, MessMess, PtBalance,
InvMass, typeTowerConstraint, ParLimit, DiJetResolution, JetConstraint, JWFit};
//! \brief Base class of a measurement
//!
//! A measurement can represent a tower, a track, or a jet.
//!
//! \note: The parametrized (pt-)measurement, wich will be compared to the
//! 'truth' will remain a single 'double' value (i.e. the
//! same type as 'truth')!
//!
//! \sa Jet, Tower, Track, JetWithTowers, JetWithTracks
//!
//! \author Christian Autermann, Hartmut Stadie
//! $Id: CalibData.h,v 1.93 2013/05/08 14:38:26 kirschen Exp $
class Measurement
{
public:
Measurement() :
pt(0.),EMF(0.),HadF(0.),OutF(0.),E(0.),eta(0.),phi(0.),phiphi(0),
etaeta(0)
{
}
Measurement(float Et,float EmEt,float HadEt,float OutEt,float E,
float eta,float phi, float nphiphi = 0,float netaeta = 0)
: pt(Et),EMF(EmEt),HadF(HadEt),OutF(OutEt),E(E),eta(eta),phi(phi),
phiphi(nphiphi),etaeta(netaeta)
{
assert(phiphi == phiphi);
}
virtual ~Measurement() {};
//all common variables
float pt; //!< Total transverse momentum (pt = EMF + HadF + OutF)
float EMF; //!< Pt from the ECAL part of the tower(s)
float HadF; //!< Pt from the HCAL part of the towers(s)
float OutF; //!< Pt fromt the HO part of the tower(s)
float E; //!< Total energy
float eta; //!< Pseudorapidity eta
float phi; //!< Polar angle phi
float phiphi; //!< Phi-Phi moment (width in phi)
float etaeta; //!< Eta-Eta moment (width in eta)
};
//! \brief A track measurement
//!
//! \sa Measurement, TJet, TTower, Jet, JetWithTowers
//!
//! \todo Document members
//!
//! \author Jan Thomsen
//! $Id: CalibData.h,v 1.93 2013/05/08 14:38:26 kirschen Exp $
class TTrack : public Measurement
{
public:
TTrack():Measurement(){};
TTrack(float Et, float EmEt, float HadEt ,float OutEt, float E,float eta,
float phi,int TrackId, int TowerId, float DR, float DRout,
float etaOut, float phiOut, float EM1, float EM5, float Had1,
float Had5, float TrackChi2, int NValidHits, bool TrackQualityT,
float MuDR, float MuDE, float Efficiency)
: Measurement(Et,EmEt,HadEt,OutEt,E,eta,phi),TrackId(TrackId),TowerId(TowerId),
NValidHits(NValidHits),TrackQualityT(TrackQualityT),DR(DR),DRout(DRout),etaOut(etaOut),
phiOut(phiOut),EM1(EM1),EM5(EM5),Had1(Had1),Had5(Had5),TrackChi2(TrackChi2),
MuDR(MuDR),MuDE(MuDE),Efficiency(Efficiency) {}
virtual ~TTrack() {}
//variables specific only to Tracks
int TrackId;
int TowerId;
int NValidHits;
bool TrackQualityT;
float DR;
float DRout;
float etaOut;
float phiOut;
float EM1;
float EM5;
float Had1;
float Had5;
float TrackChi2;
float MuDR;
float MuDE;
float Efficiency;
};
//! \brief Interface to the data
//!
//! A Event object represents one event. It holds the measured
//! quantities of that event (see Measurement) and allows
//! access to the corrected measurement. Moreover, the normalized,
//! weighted, squared, and squared residual \f$ z^{2} \f$ of this
//! event, which enters the global \f$ \chi^{2} = \sum z^{2} \f$
//! function, is calculated.
//!
//! Event is a virtual base class. The derived interfaces are
//! specific for a certain type of data.
//!
//! There are currently two different calibration schemes, resulting
//! in two different sets of data classes derived from Event:
//! -# Original calibration scheme ("Correction of the measurement")
//! There is a second base class for this scheme, TAbstractData,
//! deriving from Event. All interfaces for specific data types
//! derive from TAbstractData in this scheme.
//! -# New calibration scheme ("Variation of the truth")
//! The available data types are:
//! \author Christian Autermann
//! \date Wed Jul 18 13:54:50 CEST 2007
//! $Id: CalibData.h,v 1.93 2013/05/08 14:38:26 kirschen Exp $
class Event
{
public:
Event(float w = 0, float pthat = 0, short npu = 0, float nputruth = 0., short nvtx=0, float metraw=0, float metrawphi=0, float metT1=0, float metT1phi=0, float metT1res=0, float metT1resphi=0, float metT2=0, float metT2phi=0, float metT2res=0, float metT2resphi=0, int runNumber=0, float PUMCHighestSumPt =0, float rho=0)
:
weight_(w),ptHat_(pthat),nPU_(npu),nPUTruth_(nputruth),nVtx_(nvtx),MET_(metraw),METphi_(metrawphi),METT1_(metT1),METT1phi_(metT1phi),METT1Res_(metT1res),METT1Resphi_(metT1phi),METT2_(metT2),METT2phi_(metT2phi),METT2Res_(metT2res),METT2Resphi_(metT2phi),runNumber_(runNumber), PUMCHighestSumPt_(PUMCHighestSumPt),rho_(rho) {}
virtual ~Event() {}
virtual Measurement *mess() const = 0; //!< Get Measurement object
virtual double truth() const = 0; //!< Get truth of measurement
virtual double parametrizedMess() const = 0; //!< Get corrected measurement
virtual void setParameters(Parameters* param) = 0; //!< Set Parameters
virtual DataType type() const = 0; //!< Get DataType
float weight() const { return weight_;} //!< Get weight
void setWeight(double w) {weight_ = w;} //!< Set weight
float ptHat() const { return ptHat_; } //!< Get event scale
float nPUTruth() const { return nPUTruth_; } //! True number of PU interactions
short nPU() const { return nPU_; } //!< Number of generated (in-time) PU interactions
short nVtx() const { return nVtx_; } //!< Number of reconstructed vertices
float MET() const { return MET_; } //!< Missing transverse energy (raw)
float METphi() const { return METphi_; } //!< Azimuthal angle of missing transverse energy (raw)
float METT1() const { return METT1_; } //!< Missing transverse energy
float METT1phi() const { return METT1phi_; } //!< Azimuthal angle of missing transverse energy
float METT1Res() const { return METT1Res_; } //!< Missing transverse energy //residual corrected
float METT1Resphi() const { return METT1Resphi_; } //!< Azimuthal angle of missing transverse energy //residual corrected
float METT2() const { return METT2_; } //!< Missing transverse energy
float METT2phi() const { return METT2phi_; } //!< Azimuthal angle of missing transverse energy
float METT2Res() const { return METT2Res_; } //!< Missing transverse energy //residual corrected
float METT2Resphi() const { return METT2Resphi_; } //!< Missing transverse energy //residual corrected
int runNumber() const { return runNumber_; } //!< Number of CMS run
float PUMCHighestSumPt() const { return PUMCHighestSumPt_; } //!< Highest SumPt (of SimTracks) from mixed-in PU events
float rho() const {return rho_;} //! energy density rho
//! \brief Get the normalized, squared residual \f$ z^{2} \f$ of this event
//!
//! The normalized, squared residual \f$ z^{2} \f$ of
//! this event is calculated. It is weighted with
//! GetWeight(), and scaled with ScaleResidual.
//! It enters the global \f$ \chi^{2} = \sum z^{2} \f$
//! function.
//!
//! \return The normalized, squared residual\f$ z^{2} \f$ of this event
virtual double chi2() const = 0;
//! \brief Chi2 value from last iteration
//! \return Chi2 value from last iteration
// ------------------------------------------
virtual double chi2_plots() const = 0;
//! \brief Get the normalized, squared residual\f$ z^{2} \f$ of this event
//! and calculate the first and second derivatives
//!
//! The normalized, squared residual \f$ z^{2} \f$ of
//! this event is calculated. It is weighted with
//! GetWeight(), and scaled with ScaleResidual.
//! It enters the global \f$ \chi^{2} = \sum z^{2} \f$
//! function.
//!
//! Moreover, the contribution of this event to the
//! first and second derivative ('temp_derivative1',
//! 'temp_derivative2', 'temp_derivative3',
//! 'temp_derivative4' ) of the global \f$ \chi^{2} \f$
//! function is calculated numerically and returned
//! by reference, where
//! \f[
//! \textrm{temp\_derivative1} = \chi^{2}(x+h)-\chi^{2}(x-h)
//! \textrm{temp\_derivative2} = \chi^{2}(x+h)+\chi^{2}(x-h) -2\chi^{2}(x)
//! \textrm{temp\_derivative3} = \chi^{2}(x+2h)-\chi^{2}(x-2h)
//! \textrm{temp\_derivative4} = \chi^{2}(x+2h)+\chi^{2}(x-2h) -2\chi^{2}(x)
//! ]\f
//! \param temp_derivative1 Pointer to first derivative contribution
//! \param temp_derivative2 Pointer to second derivative contribution
//! \param epsilon Step sizes \f$ \epsilon \f$ for derivative calculation
//! \return The normalized, squared residual\f$ z^{2} \f$ of this event
virtual double chi2_fast(double * temp_derivative1, double * temp_derivative2, double * temp_derivative3, double * temp_derivative4, const double *epsilon) const = 0;
virtual void updateError() = 0; //!< Update error terms using current corrected energies
//! \brief Scale residual for outlier treatment
//!
//! Points to one of the following functions to
//! scale the squared, normalized, and weighted
//! residual
//! \f$ z^{2} = \chi^{2}/\textrm{weight} \f$:
//! - scaleNone(double z2)
//! - scaleCauchy(double z2)
//! - scaleHuber(double z2)
//! - scaleTukey(double z2)
//!
//! \param z2 Normalized and squared residual
//! \return Scaled residual
static double (*scaleResidual)(double z2);
//! \brief No scaling of residuals
//!
//! \note This is the default
//!
//! \param z2 Normalized and squared residual
//! \return Scaled residual
static double scaleNone(double z2){ return z2; }
static double scaleCauchy(double z2); //!< Scaling of residual with Cauchy function
static double scaleHuber(double z2); //!< Scaling of residual with Huber function
//! \brief Cut on residuals
//!
//! discards events with \f$ |residual| > 1.5 \sigma \f$
//!
//! \param z2 Normalized and squared residual
//! \return Scaled residual
static double scaleTukey(double z2); //!< Scaling of residual a la Tukey
protected:
float weight_;
float ptHat_;
short nPU_;
float nPUTruth_;
short nVtx_;
float MET_;
float METphi_;
float METT1_;
float METT1phi_;
float METT1Res_;
float METT1Resphi_;
float METT2_;
float METT2phi_;
float METT2Res_;
float METT2Resphi_;
int runNumber_;
float PUMCHighestSumPt_;
float rho_;
};
#endif