CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
GlobalHitsAnalyzer.h
Go to the documentation of this file.
1 #ifndef GlobalHitsAnalyzer_h
2 #define GlobalHitsAnalyzer_h
3 
11 // framework & common header files
25 
26 // DQM services
29 
30 // tracker info
35 
36 // muon info
44 
45 // calorimeter info
51 
52 // data in edm::event
58 
59 // helper files
60 //#include <CLHEP/Vector/LorentzVector.h>
61 #include "CLHEP/Units/GlobalSystemOfUnits.h"
63 
64 #include <cstdlib>
65 #include <memory>
66 #include <string>
67 #include <vector>
68 
70 #include "TString.h"
71 
73 class CaloGeometryRecord;
76 public:
77  // typedef std::vector<float> FloatVector;
78 
79  explicit GlobalHitsAnalyzer(const edm::ParameterSet &);
80  ~GlobalHitsAnalyzer() override;
81  void analyze(const edm::Event &, const edm::EventSetup &) override;
82 
83 protected:
84  void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override;
85 
86 private:
87  // production related methods
88  void fillG4MC(const edm::Event &);
89  void fillTrk(const edm::Event &, const edm::EventSetup &);
90  void fillMuon(const edm::Event &, const edm::EventSetup &);
91  void fillECal(const edm::Event &, const edm::EventSetup &);
92  void fillHCal(const edm::Event &, const edm::EventSetup &);
93 
94 private:
95  // parameter information
97  int verbosity;
98  int frequency;
99  int vtxunit;
104 
123  bool validEB;
124  bool validEE;
126  bool validHcal;
127 
128  // G4MC info
142 
147 
154 
155  // Electromagnetic info
156  // ECal info
166 
167  // Preshower info
175 
176  // Hadronic info
177  // HCal info
185 
186  // Tracker info
187  // Pixel info
188  int nPxlHits;
204 
205  // Strip info
206  int nSiHits;
230 
231  // Muon info
236 
237  // DT info
242  // CSC info
247  // RPC info
254 
255  // private statistics information
256  unsigned int count;
257 
258 }; // end class declaration
259 
260 #endif
261 
262 #ifndef GlobalHitMap
263 #define GlobalHitMap
264 // geometry mapping
265 static const int dTrk = 1;
266 static const int sdPxlBrl = 1;
267 static const int sdPxlFwd = 2;
268 static const int sdSiTIB = 3;
269 static const int sdSiTID = 4;
270 static const int sdSiTOB = 5;
271 static const int sdSiTEC = 6;
272 
273 static const int dMuon = 2;
274 static const int sdMuonDT = 1;
275 static const int sdMuonCSC = 2;
276 static const int sdMuonRPC = 3;
277 static const int sdMuonRPCRgnBrl = 0;
278 static const int sdMuonRPCRgnFwdp = 1;
279 static const int sdMuonRPCRgnFwdn = -1;
280 
281 static const int dEcal = 3;
282 static const int sdEcalBrl = 1;
283 static const int sdEcalFwd = 2;
284 static const int sdEcalPS = 3;
285 static const int sdEcalTT = 4;
286 static const int sdEcalLPnD = 5;
287 
288 static const int dHcal = 4;
289 static const int sdHcalEmpty = 0;
290 static const int sdHcalBrl = 1;
291 static const int sdHcalEC = 2;
292 static const int sdHcalOut = 3;
293 static const int sdHcalFwd = 4;
294 static const int sdHcalTT = 5;
295 static const int sdHcalCalib = 6;
296 static const int sdHcalCompst = 7;
297 
298 #endif
MonitorElement * meTrackerSiPhi
edm::EDGetTokenT< edm::PSimHitContainer > SiTIDLowSrc_Token_
void fillG4MC(const edm::Event &)
edm::ESGetToken< CaloGeometry, CaloGeometryRecord > caloGeomToken_
static const int sdEcalPS
edm::InputTag SiTECLowSrc_
static const int sdHcalFwd
edm::EDGetTokenT< edm::PSimHitContainer > SiTECHighSrc_Token_
static const int sdHcalCompst
edm::InputTag PxlBrlLowSrc_
edm::InputTag MuonDtSrc_
static const int sdHcalOut
edm::ESGetToken< DTGeometry, MuonGeometryRecord > dtGeomToken_
static const int dEcal
static const int sdHcalCalib
static const int sdEcalTT
MonitorElement * meMuonDtToF[2]
MonitorElement * meGeantVtxRad[2]
MonitorElement * meCaloHcal[2]
static const int sdPxlBrl
MonitorElement * meMCG4Trk[2]
edm::ESGetToken< HcalDDDRecConstants, HcalRecNumberingRecord > hcaldddRecToken_
MonitorElement * meTrackerPxPhi
MonitorElement * meCaloHcalToF[2]
edm::EDGetTokenT< edm::PSimHitContainer > SiTIDHighSrc_Token_
MonitorElement * meCaloPreSh[2]
edm::EDGetTokenT< edm::PCaloHitContainer > ECalEESrc_Token_
MonitorElement * meTrackerSiEta
static const int sdMuonRPC
static const int sdMuonCSC
void fillHCal(const edm::Event &, const edm::EventSetup &)
MonitorElement * meTrackerSiBToF
MonitorElement * meTrackerSi[2]
edm::EDGetTokenT< edm::SimTrackContainer > G4TrkSrc_Token_
static const int sdMuonRPCRgnFwdp
static const int sdSiTIB
edm::EDGetTokenT< edm::PSimHitContainer > SiTIBHighSrc_Token_
MonitorElement * meMCG4Vtx[2]
static const int dMuon
edm::InputTag SiTIBHighSrc_
MonitorElement * meGeantVtxY[2]
MonitorElement * meGeantVtxMulti
static const int sdEcalBrl
MonitorElement * meTrackerPxFZ
edm::InputTag MuonCscSrc_
edm::InputTag PxlBrlHighSrc_
static const int sdMuonDT
static const int sdHcalBrl
static const int sdEcalLPnD
MonitorElement * meMuonCscToF[2]
MonitorElement * meCaloPreShPhi
MonitorElement * meGeantTrkE
MonitorElement * meCaloEcalEta
static const int sdMuonRPCRgnBrl
MonitorElement * meTrackerPxBR
static const int sdSiTID
MonitorElement * meCaloPreShE[2]
edm::InputTag PxlFwdLowSrc_
MonitorElement * meTrackerPxBToF
MonitorElement * meGeantVtxPhi
edm::InputTag SiTIDLowSrc_
edm::InputTag ECalESSrc_
MonitorElement * meCaloEcalPhi
edm::EDGetTokenT< edm::PSimHitContainer > SiTIBLowSrc_Token_
MonitorElement * meTrackerPx[2]
MonitorElement * meGeantTrkPt
MonitorElement * meGeantVtxEta
edm::InputTag PxlFwdHighSrc_
MonitorElement * meMuonRpcFZ
edm::EDGetTokenT< edm::PSimHitContainer > PxlBrlHighSrc_Token_
edm::InputTag SiTECHighSrc_
edm::EDGetTokenT< edm::PCaloHitContainer > ECalEBSrc_Token_
void fillTrk(const edm::Event &, const edm::EventSetup &)
MonitorElement * meMCRGP[2]
edm::EDGetTokenT< edm::PSimHitContainer > PxlBrlLowSrc_Token_
MonitorElement * meMuonRpcBToF[2]
static const int dHcal
static const int sdHcalTT
MonitorElement * meCaloHcalE[2]
MonitorElement * meMuonCscZ
MonitorElement * meGeantVtxX[2]
void fillMuon(const edm::Event &, const edm::EventSetup &)
edm::EDGetTokenT< edm::PSimHitContainer > SiTOBLowSrc_Token_
edm::ESGetToken< CSCGeometry, MuonGeometryRecord > cscGeomToken_
edm::EDGetTokenT< edm::PSimHitContainer > MuonRpcSrc_Token_
MonitorElement * meCaloEcal[2]
edm::EDGetTokenT< edm::PSimHitContainer > PxlFwdLowSrc_Token_
static const int sdMuonRPCRgnFwdn
MonitorElement * meTrackerSiFZ
MonitorElement * meGeantVtxZ[2]
MonitorElement * meCaloEcalToF[2]
edm::EDGetTokenT< edm::PSimHitContainer > SiTOBHighSrc_Token_
edm::EDGetTokenT< edm::PSimHitContainer > MuonCscSrc_Token_
static const int sdSiTOB
static const int sdSiTEC
void fillECal(const edm::Event &, const edm::EventSetup &)
edm::InputTag SiTIDHighSrc_
MonitorElement * meMuon[2]
MonitorElement * meMuonRpcFToF[2]
MonitorElement * meCaloPreShToF[2]
MonitorElement * meCaloPreShEta
MonitorElement * meTrackerSiFToF
MonitorElement * meTrackerPxFToF
edm::InputTag MuonRpcSrc_
edm::EDGetTokenT< edm::SimVertexContainer > G4VtxSrc_Token_
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
MonitorElement * meMuonEta
edm::InputTag SiTOBLowSrc_
edm::InputTag SiTOBHighSrc_
MonitorElement * meMuonDtR
static const int dTrk
edm::InputTag ECalEBSrc_
static const int sdPxlFwd
edm::EDGetTokenT< edm::PCaloHitContainer > HCalSrc_Token_
edm::EDGetTokenT< edm::PSimHitContainer > PxlFwdHighSrc_Token_
edm::InputTag SiTIBLowSrc_
MonitorElement * meCaloHcalPhi
edm::ESGetToken< RPCGeometry, MuonGeometryRecord > rpcGeomToken_
static const int sdEcalFwd
static const int sdHcalEC
MonitorElement * meMuonRpcBR
edm::InputTag ECalEESrc_
MonitorElement * meTrackerPxEta
static const int sdHcalEmpty
edm::EDGetTokenT< edm::PCaloHitContainer > ECalESSrc_Token_
MonitorElement * meCaloHcalEta
MonitorElement * meMuonPhi
Definition: Run.h:45
GlobalHitsAnalyzer(const edm::ParameterSet &)
edm::EDGetTokenT< edm::PSimHitContainer > MuonDtSrc_Token_
edm::EDGetTokenT< edm::PSimHitContainer > SiTECLowSrc_Token_
edm::ESGetToken< TrackerGeometry, TrackerDigiGeometryRecord > tGeomToken_
MonitorElement * meTrackerSiBR
void analyze(const edm::Event &, const edm::EventSetup &) override
MonitorElement * meCaloEcalE[2]