CMS 3D CMS Logo

CSCSegmentValidation.h
Go to the documentation of this file.
1 #ifndef CSCSegmentValidation_h
2 #define CSCSegmentValidation_h
3 
11 
13 {
14 public:
17  virtual ~CSCSegmentValidation();
19  virtual void analyze(const edm::Event&, const edm::EventSetup&);
20 
21  private:
22  void plotResolution(const PSimHit & simHit, const CSCSegment & recHit,
23  const CSCLayer * layer, int chamberType);
24 
25  bool hasSegment(int chamberId) const;
26  static int whatChamberType(int detId);
27 
29 
30  // map to count how many layers are hit. First index is chamber detId, second is layers
31  // that have hits
32  typedef std::map<int, std::vector<int> > ChamberHitMap;
33  ChamberHitMap theLayerHitsPerChamber;
35  void fillEfficiencyPlots();
36  // decide which SimHit to use for the direction
37  const PSimHit * keyHit(int chamberId) const;
38 
39  typedef std::map<int, std::vector<CSCSegment> > ChamberSegmentMap;
40  ChamberSegmentMap theChamberSegmentMap;
41  // the number of hits in a chamber to make it a shower
43 
55 
68 };
69 
70 #endif
71 
MonitorElement * theNPerEventPlot
void plotResolution(const PSimHit &simHit, const CSCSegment &recHit, const CSCLayer *layer, int chamberType)
MonitorElement * theTypePlot5HitsNoShowerSeg
std::map< int, std::vector< int > > ChamberHitMap
MonitorElement * theTypePlot4HitsShowerSeg
MonitorElement * theNPerChamberTypePlot
static int whatChamberType(int detId)
MonitorElement * theTypePlot6HitsShower
MonitorElement * theTypePlot5HitsNoShower
edm::EDGetTokenT< CSCSegmentCollection > segments_Token_
MonitorElement * theNRecHitsPlot
MonitorElement * theTypePlot4HitsShower
MonitorElement * theRdPhiResolutionPlots[10]
MonitorElement * theTypePlot6HitsShowerSeg
MonitorElement * theTypePlot4HitsNoShower
MonitorElement * theTypePlot6HitsNoShowerSeg
std::map< int, std::vector< CSCSegment > > ChamberSegmentMap
MonitorElement * theTypePlot6HitsNoShower
ChamberHitMap theLayerHitsPerChamber
MonitorElement * thedYdZResolutionPlots[10]
MonitorElement * theRdPhiPullPlots[10]
virtual void analyze(const edm::Event &, const edm::EventSetup &)
MonitorElement * theThetaPullPlots[10]
const PSimHit * keyHit(int chamberId) const
MonitorElement * thedXdZPullPlots[10]
bool hasSegment(int chamberId) const
MonitorElement * theTypePlot5HitsShowerSeg
MonitorElement * theThetaResolutionPlots[10]
ChamberSegmentMap theChamberSegmentMap
MonitorElement * theTypePlot4HitsNoShowerSeg
void bookHistograms(DQMStore::IBooker &)
CSCSegmentValidation(const edm::InputTag &inputTag, edm::ConsumesCollector &&iC)
MonitorElement * theTypePlot5HitsShower
MonitorElement * thedXdZResolutionPlots[10]
MonitorElement * thedYdZPullPlots[10]