Fork me on GitHub

source: svn/trunk/modules/Calorimeter.h@ 1374

Last change on this file since 1374 was 1369, checked in by Michele Selvaggi, 11 years ago

added simplecalo

  • Property svn:keywords set to Id Revision Date
File size: 2.1 KB
RevLine 
[608]1#ifndef Calorimeter_h
2#define Calorimeter_h
3
[814]4/** \class Calorimeter
5 *
[894]6 * Fills calorimeter towers, performs calorimeter resolution smearing,
[1356]7 * and creates energy flow objects (tracks, photons, and neutral hadrons).
[814]8 *
9 * $Date: 2014-04-16 15:17:35 +0000 (Wed, 16 Apr 2014) $
10 * $Revision: 1369 $
11 *
12 *
13 * \author P. Demin - UCL, Louvain-la-Neuve
14 *
15 */
16
[687]17#include "classes/DelphesModule.h"
[608]18
19#include <map>
20#include <set>
[659]21#include <vector>
[608]22
23class TObjArray;
[766]24class DelphesFormula;
[687]25class Candidate;
[608]26
[687]27class Calorimeter: public DelphesModule
[608]28{
29public:
30
31 Calorimeter();
32 ~Calorimeter();
33
34 void Init();
35 void Process();
36 void Finish();
[1145]37
[608]38private:
39
[1369]40 typedef std::map< Long64_t, std::pair< Double_t, Double_t > > TFractionMap; //!
[659]41 typedef std::map< Double_t, std::set< Double_t > > TBinMap; //!
[931]42
[730]43 Candidate *fTower;
[898]44 Double_t fTowerEta, fTowerPhi, fTowerEdges[4];
[1369]45 Double_t fTowerECalEnergy, fTowerHCalEnergy;
46 Double_t fTrackECalEnergy, fTrackHCalEnergy;
[1345]47
[1369]48 Double_t fTowerECalTime, fTowerHCalTime;
49 Double_t fTrackECalTime, fTrackHCalTime;
[1345]50
[1369]51 Double_t fTowerECalWeightTime, fTowerHCalWeightTime;
52 Double_t fTrackECalWeightTime, fTrackHCalWeightTime;
[1345]53
[1273]54 Int_t fTowerTrackHits, fTowerPhotonHits;
[730]55
[608]56 TFractionMap fFractionMap; //!
[622]57 TBinMap fBinMap; //!
[931]58
[659]59 std::vector < Double_t > fEtaBins;
60 std::vector < std::vector < Double_t >* > fPhiBins;
[931]61
[661]62 std::vector < Long64_t > fTowerHits;
63
[1369]64 std::vector < Double_t > fTowerECalFractions;
65 std::vector < Double_t > fTowerHCalFractions;
66
67 std::vector < Double_t > fTrackECalFractions;
68 std::vector < Double_t > fTrackHCalFractions;
69
70 DelphesFormula *fECalResolutionFormula; //!
71 DelphesFormula *fHCalResolutionFormula; //!
72
[886]73 TIterator *fItParticleInputArray; //!
74 TIterator *fItTrackInputArray; //!
[608]75
[886]76 const TObjArray *fParticleInputArray; //!
77 const TObjArray *fTrackInputArray; //!
[608]78
[629]79 TObjArray *fTowerOutputArray; //!
[1369]80 TObjArray *fPhotonOutputArray; //!
[1356]81
[1369]82 TObjArray *fEFlowTrackOutputArray; //!
83 TObjArray *fEFlowPhotonOutputArray; //!
84 TObjArray *fEFlowNeutralHadronOutputArray; //!
85
[1235]86 TObjArray *fTowerTrackArray; //!
87 TIterator *fItTowerTrackArray; //!
88
[730]89 void FinalizeTower();
[1145]90 Double_t LogNormal(Double_t mean, Double_t sigma);
91
[608]92 ClassDef(Calorimeter, 1)
93};
94
95#endif
Note: See TracBrowser for help on using the repository browser.