Fork me on GitHub

source: svn/trunk/Utilities/ExRootAnalysis/interface/BlockClasses.h@ 310

Last change on this file since 310 was 310, checked in by severine ovyn, 16 years ago

add Ehad/Eem

File size: 15.1 KB
Line 
1#ifndef BLOCKCLASSES_H
2#define BLOCKCLASSES_H
3
4/***********************************************************************
5** **
6** /----------------------------------------------\ **
7** | Delphes, a framework for the fast simulation | **
8** | of a generic collider experiment | **
9** \----------------------------------------------/ **
10** **
11** **
12** This package uses: **
13** ------------------ **
14** FastJet algorithm: Phys. Lett. B641 (2006) [hep-ph/0512210] **
15** Hector: JINST 2:P09005 (2007) [physics.acc-ph:0707.1198v2] **
16** FROG: [hep-ex/0901.2718v1] **
17** **
18** ------------------------------------------------------------------ **
19** **
20** Main authors: **
21** ------------- **
22** **
23** Severine Ovyn Xavier Rouby **
24** severine.ovyn@uclouvain.be xavier.rouby@cern **
25** **
26** Center for Particle Physics and Phenomenology (CP3) **
27** Universite catholique de Louvain (UCL) **
28** Louvain-la-Neuve, Belgium **
29** **
30** Copyright (C) 2008-2009, **
31** All rights reserved. **
32** **
33***********************************************************************/
34
35#include "TLorentzVector.h"
36#include "TObject.h"
37#include "BlockCompare.h"
38#include "interface/D_Constants.h"
39#include "interface/CaloUtil.h"
40
41class TSortableObject: public TObject
42{
43public:
44 TSortableObject() {};
45 Bool_t IsSortable() const { return GetCompare() ? GetCompare()->IsSortable(this) : kFALSE; }
46 Int_t Compare(const TObject *obj) const { return GetCompare()->Compare(this, obj); }
47
48 virtual const TCompare *GetCompare() const = 0;
49
50 ClassDef(TSortableObject, 1)
51};
52
53//---------------------------------------------------------------------------
54//
55class TRootLHEFEvent: public TObject
56{
57public:
58 TRootLHEFEvent() {};
59
60 Long64_t Number; // event number
61
62 int Nparticles; // number of particles in the event | hepup.NUP
63 int ProcessID; // subprocess code for the event | hepup.IDPRUP
64
65 Double_t Weight; // weight for the event | hepup.XWGTUP
66 Double_t ScalePDF; // scale in GeV used in the calculation of the PDFs in the event | hepup.SCALUP
67 Double_t CouplingQED; // value of the QED coupling used in the event | hepup.AQEDUP
68 Double_t CouplingQCD; // value of the QCD coupling used in the event | hepup.AQCDUP
69
70 ClassDef(TRootLHEFEvent, 2)
71};
72
73//---------------------------------------------------------------------------
74
75class TRootLHEFParticle: public TSortableObject
76{
77public:
78 TRootLHEFParticle() {};
79 int PID; // particle HEP ID number | hepup.IDUP[number]
80 int Status; // particle status code | hepup.ISTUP[number]
81 int Mother1; // index for the particle first mother | hepup.MOTHUP[number][0]
82 int Mother2; // index for the particle last mother | hepup.MOTHUP[number][1]
83 int ColorLine1; // index for the particle color-line | hepup.ICOLUP[number][0]
84 int ColorLine2; // index for the particle anti-color-line | hepup.ICOLUP[number][1]
85
86 double Px; // particle momentum vector (x component) | hepup.PUP[number][0]
87 double Py; // particle momentum vector (y component) | hepup.PUP[number][1]
88 double Pz; // particle momentum vector (z component) | hepup.PUP[number][2]
89 double E; // particle energy | hepup.PUP[number][3]
90 double M; // particle mass | hepup.PUP[number][4]
91
92 double PT; // particle transverse momentum
93 double Eta; // particle pseudorapidity
94 double Phi; // particle azimuthal angle
95
96 double Rapidity; // particle rapidity
97
98 double LifeTime; // particle invariant lifetime
99 // (c*tau, distance from production to decay in mm)
100 // | hepup.VTIMUP[number]
101
102 double Spin; // cosine of the angle between the particle spin vector
103 // and the decaying particle 3-momentum,
104 // specified in the lab frame. | hepup.SPINUP[number]
105
106 static TCompare *fgCompare; //!
107 const TCompare *GetCompare() const { return fgCompare; }
108 ClassDef(TRootLHEFParticle, 2)
109
110};
111
112//---------------------------------------------------------------------------
113
114class TRootSelectorInfo: public TObject
115{
116public:
117 TRootSelectorInfo() {};
118 int Processed; // current number of processed events
119 int Accepted; // current number of accepted events
120
121 ClassDef(TRootSelectorInfo, 1)
122};
123
124
125class TRootGenEvent: public TObject
126{
127public:
128 TRootGenEvent() {};
129 Long64_t Number; // event number | hepevt.nevhep
130
131 static TCompare *fgCompare; //!
132 const TCompare *GetCompare() const { return fgCompare; }
133
134 ClassDef(TRootGenEvent, 1)
135};
136
137
138class TRootEvent: public TObject {
139
140public:
141 TRootEvent() {};
142 int Run; // run number [G3EventProxy::simSignal().id().runNumber()]
143 int Event; // event number [G3EventProxy::simSignal().id().eventInRun()]
144
145// Short_t L1Decision; // L1 trigger global decision [L1Trigger::decision()]
146// Short_t HLTDecision; // HLT trigger global decision [HighLevelTriggerResult::getGlobalDecision()]
147
148 ClassDef(TRootEvent, 1)
149};
150
151//---------------------------------------------------------------------------
152
153class TRootParticle: public TSortableObject {
154
155public:
156
157 TRootParticle() {};
158 float E; // particle energy in GeV
159 float Px; // particle momentum vector (x component) in GeV
160 float Py; // particle momentum vector (y component) in GeV
161 float Pz; // particle momentum vector (z component) in GeV
162
163 float Eta; // particle pseudorapidity
164 float Phi; // particle azimuthal angle in rad
165
166 void Set(const TLorentzVector& momentum);
167 void Set(const float px, const float py, const float pz, const float e);
168 void SetEtaPhi(const float eta, const float phi) {Eta=eta; Phi=phi;};
169 void SetEtaPhiEET(const float eta, const float phi, const float e, const float et);
170 static TCompare *fgCompare; //!
171 const TCompare *GetCompare() const { return fgCompare; }
172 float PT; // particle transverse momentum in GeV
173
174 ClassDef(TRootParticle, 1)
175};
176
177//--------------------------------------------------------------------------
178
179class GenParticle: public TRootParticle {
180
181public:
182 GenParticle() {};
183 int PID; // particle HEP ID number [RawHepEventParticle::pid()]
184 int Status; // particle status [RawHepEventParticle::status()]
185 int M1; // particle 1st mother [RawHepEventParticle::mother1() - 1]
186 int M2; // particle 2nd mother [RawHepEventParticle::mother2() - 1]
187 int D1; // particle 1st daughter [RawHepEventParticle::daughter1() - 1]
188 int D2; // particle 2nd daughter [RawHepEventParticle::daughter2() - 1]
189
190 float Charge;
191
192 float T; // particle vertex position (t component) [RawHepEventParticle::t()]
193 float X; // particle vertex position (x component) [RawHepEventParticle::x()]
194 float Y; // particle vertex position (y component) [RawHepEventParticle::y()]
195 float Z; // particle vertex position (z component) [RawHepEventParticle::z()]
196 float M;
197
198
199 static TCompare *fgCompare; //!
200
201 ClassDef(GenParticle, 1)
202};
203
204//---------------------------------------------------------------------------
205
206class TRootGenParticle: public TRootParticle {
207
208public:
209 TRootGenParticle() {_initialised=false;}
210 TRootGenParticle(GenParticle* part);
211
212 int PID; // particle HEP ID number [RawHepEventParticle::pid()]
213 int Status; // particle status [RawHepEventParticle::status()]
214 int M1; // particle 1st mother [RawHepEventParticle::mother1() - 1]
215 int M2; // particle 2nd mother [RawHepEventParticle::mother2() - 1]
216 int D1; // particle 1st daughter [RawHepEventParticle::daughter1() - 1]
217 int D2; // particle 2nd daughter [RawHepEventParticle::daughter2() - 1]
218
219 float T; // particle vertex position (t component) [RawHepEventParticle::t()]
220 float X; // particle vertex position (x component) [RawHepEventParticle::x()]
221 float Y; // particle vertex position (y component) [RawHepEventParticle::y()]
222 float Z; // particle vertex position (z component) [RawHepEventParticle::z()]
223 float M;
224 void setFractions();
225 const float getFem() {if(!_initialised) setFractions(); return _Fem;}
226 const float getFhad() {if(!_initialised) setFractions(); return _Fhad;}
227
228 float EtaCalo; // particle pseudorapidity when entering the calo,
229 float PhiCalo; // particle azimuthal angle in rad when entering the calo
230 void SetEtaPhiCalo(const float eta, const float phi) {EtaCalo=eta; PhiCalo=phi;};
231
232 static TCompare *fgCompare; //!
233
234 float Charge; // electrical charge
235 protected:
236 float _Fem, _Fhad; // fractions of energy deposit
237 bool _initialised;
238 ClassDef(TRootGenParticle, 1)
239};
240
241
242//------------------------------------------------------------------------------
243
244class TRootElectron: public TRootParticle
245{
246public:
247 TRootElectron() {};
248 int Charge; // particle Charge [RawHepEventParticle::pid()]
249 static TCompare *fgCompare; //!
250
251 float EtaCalo; // particle pseudorapidity when entering the calo,
252 float PhiCalo; // particle azimuthal angle in rad when entering the calo
253 void SetEtaPhiCalo(const float eta, const float phi) {EtaCalo=eta; PhiCalo=phi;};
254
255 float EHoverEE;
256 bool IsolFlag;
257
258 ClassDef(TRootElectron, 1)
259};
260
261//------------------------------------------------------------------------------
262
263class TRootPhoton: public TRootParticle
264{
265public:
266 TRootPhoton() {};
267 static TCompare *fgCompare; //!
268
269 float EHoverEE;
270 ClassDef(TRootPhoton, 1)
271};
272
273
274//------------------------------------------------------------------------------
275
276class TRootMuon: public TRootParticle
277{
278public:
279 TRootMuon() {};
280 int Charge; // particle Charge [RawHepEventParticle::pid()]
281 bool IsolFlag;
282 float EtaCalo; // particle pseudorapidity when entering the calo,
283 float PhiCalo; // particle azimuthal angle in rad when entering the calo
284 void SetEtaPhiCalo(const float eta, const float phi) {EtaCalo=eta; PhiCalo=phi;};
285
286 float EHoverEE;
287 static TCompare *fgCompare; //!
288
289 ClassDef(TRootMuon, 1)
290};
291
292//---------------------------------------------------------------------------
293
294class TRootTracks : public TSortableObject {
295 public:
296 TRootTracks(); // needed for storage in ExRootAnalysis
297 TRootTracks(const TRootTracks& track);
298 TRootTracks(const float inEta, const float inPhi, const float outEta, const float outPhi, const float pt);
299 TRootTracks& operator=(const TRootTracks& track);
300 void Set(const float inEta, const float inPhi, const float outEta, const float outPhi, const float pt, const float charge);
301 const TLorentzVector GetFourVector() const;
302 const float getEta() const {return Eta;}
303 const float getPhi() const {return Phi;}
304 const float getEtaOuter() const {return EtaOuter;}
305 const float getPhiOuter() const {return PhiOuter;}
306
307 static TCompare *fgCompare; //!
308 const TCompare *GetCompare() const { return fgCompare; }
309
310 float Eta, Phi; // (eta,phi) at the beginning of the track
311 float EtaOuter, PhiOuter; // (eta,phi) at the end of the track
312 float PT, E, Px, Py, Pz; // transverse momentum
313 float Charge;
314 ClassDef(TRootTracks, 1)
315};
316
317//---------------------------------------------------------------------------
318
319class TRootCalo: public TSortableObject
320{
321//class TRootCalo: public TRootParticle {
322 public:
323 float Eta;
324 float Phi;
325 float E;
326 TRootCalo() ;
327 TRootCalo(const TRootCalo& cal);
328 TRootCalo& operator=(const TRootCalo& cal);
329 void set(const D_CaloTower& cal);
330 static TCompare *fgCompare; //!
331 const TCompare *GetCompare() const { return fgCompare; }
332 const float getET() const {return ET;}
333
334 protected:
335 float E_em, E_had; // electromagnetic and hadronic components of the tower energy
336 float ET; // total energy and transverse energy
337 ClassDef(TRootCalo, 1)
338};
339
340//---------------------------------------------------------------------------
341class TRootZdcHits: public TRootParticle
342{
343public:
344 TRootZdcHits() {};
345 float T; // time of flight [s]
346 int side; // -1 or +1
347 static TCompare *fgCompare; //!
348
349 ClassDef(TRootZdcHits, 1)
350};
351
352//---------------------------------------------------------------------------
353
354class TRootTauJet: public TRootParticle
355{
356public:
357 TRootTauJet() {};
358 float Charge; // normally, using the charge of the track ; here using gen-level tau charge
359 int NTracks;
360
361 float EHoverEE;
362// float E; // particle energy in GeV
363// float Px; // particle momentum vector (x component) in GeV
364// float Py; // particle momentum vector (y component) in GeV
365// float Pz; // particle momentum vector (z component) in GeV
366
367// float Eta; // particle pseudorapidity
368// float Phi; // particle azimuthal angle in rad
369
370 void Set(const TLorentzVector& momentum);// { return TRootParticle::Set(momentum); }
371
372 static TCompare *fgCompare; //!
373
374 // float PT; // particle transverse momentum in GeV
375
376 ClassDef(TRootTauJet, 1)
377};
378
379//---------------------------------------------------------------------------
380
381class TRootJet: public TRootParticle
382{
383public:
384 TRootJet() {};
385
386 static TCompare *fgCompare; //!
387
388 bool Btag;
389 int NTracks;
390
391 float EHoverEE;
392 ClassDef(TRootJet, 1)
393};
394
395//------------------------------------------------------------------------------
396
397class TRootTrigger: public TSortableObject
398{
399public:
400 TRootTrigger() {};
401
402 int Accepted;
403
404 static TCompare *fgCompare; //!
405 const TCompare *GetCompare() const { return fgCompare; }
406
407 ClassDef(TRootTrigger, 1)
408};
409//---------------------------------------------------------------------------
410
411class TRootETmis: public TSortableObject
412{
413public:
414 TRootETmis() {};
415 float ET; // jet energy [RecJet::getEnergy()]
416 float Phi; // jet azimuthal angle [RecJet::getPhi()]
417 float Px;
418 float Py;
419
420 static TCompare *fgCompare; //!
421 const TCompare *GetCompare() const { return fgCompare; }
422
423 ClassDef(TRootETmis, 1)
424};
425
426//---------------------------------------------------------------------------
427
428class TRootRomanPotHits: public TSortableObject
429{
430public:
431 TRootRomanPotHits() {};
432 float T; // time of flight to the detector [s]
433 float S; // distance to the IP [m]
434 float E; // reconstructed energy [GeV]
435 float q2; // reconstructed squared momentum transfer [GeV^2]
436
437 float X; // horizontal distance to the beam [um]
438 float Y; // vertical distance to the beam [um]
439
440 float Tx; // angle of the momentum in the horizontal (x,z) plane [urad]
441 float Ty; // angle of the momentum in the verical (y,z) plane [urad]
442
443 int side; // -1 or 1
444
445 static TCompare *fgCompare; //!
446 const TCompare *GetCompare() const { return fgCompare; }
447
448 ClassDef(TRootRomanPotHits, 1)
449};
450
451#endif // BLOCKCLASSES_H
452
Note: See TracBrowser for help on using the repository browser.