CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Member Functions | Private Attributes
RPCMon_SS_Dbx_Global Class Reference

#include <RPCMon_SS_Dbx_Global.h>

Inheritance diagram for RPCMon_SS_Dbx_Global:
edm::EDAnalyzer edm::EDConsumerBase

Public Member Functions

 RPCMon_SS_Dbx_Global (const edm::ParameterSet &)
 
 ~RPCMon_SS_Dbx_Global ()
 
- Public Member Functions inherited from edm::EDAnalyzer
 EDAnalyzer ()
 
std::string workerType () const
 
virtual ~EDAnalyzer ()
 
- Public Member Functions inherited from edm::EDConsumerBase
 EDConsumerBase ()
 
ProductHolderIndex indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Member Functions

virtual void analyze (const edm::Event &, const edm::EventSetup &)
 
virtual void beginJob ()
 
void beginRun (const edm::Run &, const edm::EventSetup &)
 
virtual void endJob ()
 

Private Attributes

DQMStoredbe_
 
std::string digiLabel_
 
std::string globalFolder_
 
int numberOfRings_
 
std::string rootFileName_
 
edm::InputTag rpcDigiCollectionTag_
 
bool saveRootFile_
 

Additional Inherited Members

- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
typedef WorkerT< EDAnalyzerWorkerType
 
- Static Public Member Functions inherited from edm::EDAnalyzer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
- Protected Member Functions inherited from edm::EDAnalyzer
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
CurrentProcessingContext const * currentContext () const
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 

Detailed Description

Definition at line 16 of file RPCMon_SS_Dbx_Global.h.

Constructor & Destructor Documentation

RPCMon_SS_Dbx_Global::RPCMon_SS_Dbx_Global ( const edm::ParameterSet iConfig)
explicit

Definition at line 19 of file RPCMon_SS_Dbx_Global.cc.

References digiLabel_, edm::ParameterSet::getUntrackedParameter(), globalFolder_, numberOfRings_, rootFileName_, saveRootFile_, and AlCaHLTBitMon_QueryRunRegistry::string.

19  :
20  rpcDigiCollectionTag_(iConfig.getParameter<edm::InputTag>("rpcDigiCollectionTag")) {
21 
22 
23  edm::LogVerbatim ("rpcmonitorerror") << "[RPCMon_SS_Dbx_Global]: Constructor";
24 
25 
26  globalFolder_ = iConfig.getUntrackedParameter<std::string>("GlobalHistogramsFolder","RPC/RecHits/SummaryHistograms");
27 
28  saveRootFile_ = iConfig.getUntrackedParameter<bool>("SaveRootFile", false);
29  rootFileName_ = iConfig.getUntrackedParameter<std::string>("RootFileName","out.root");
30  digiLabel_ = iConfig.getUntrackedParameter<std::string>("DigiLabel","muonRPCDigis");
31  numberOfRings_ = iConfig.getUntrackedParameter<int>("NumberOfEndcapRings", 2);
32 
33 }
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
edm::InputTag rpcDigiCollectionTag_
RPCMon_SS_Dbx_Global::~RPCMon_SS_Dbx_Global ( )

Definition at line 35 of file RPCMon_SS_Dbx_Global.cc.

References dbe_.

35  {
36  edm::LogVerbatim ("rpcmonitorerror") << "[RPCMon_SS_Dbx_Global]: Destructor ";
37  dbe_=0;
38 }

Member Function Documentation

void RPCMon_SS_Dbx_Global::analyze ( const edm::Event iEvent,
const edm::EventSetup iSetup 
)
privatevirtual

Implements edm::EDAnalyzer.

Definition at line 60 of file RPCMon_SS_Dbx_Global.cc.

References abs, DQMStore::book2D(), RPCGeomServ::chambernr(), dbe_, MonitorElement::Fill(), edm::EventSetup::get(), DQMStore::get(), edm::Event::getByLabel(), globalFolder_, rpcdqm::utils::labelXAxisSector(), rpcdqm::utils::labelXAxisSegment(), rpcdqm::utils::labelYAxisRing(), rpcdqm::utils::labelYAxisRoll(), RPCGeomServ::name(), mergeVDriftHistosByStation::name, RPCRoll::nstrips(), numberOfRings_, relativeConstraints::ring, rpcDigiCollectionTag_, RPCGeomServ::segment(), DQMStore::setCurrentFolder(), AlCaHLTBitMon_QueryRunRegistry::string, GlobalPosition_Frontier_DevDB_cff::tag, and cuy::yBin.

60  {
61 
63  iEvent.getByLabel(rpcDigiCollectionTag_, rpcDigis);
64 
66  iSetup.get<MuonGeometryRecord>().get( pDD );
67  rpcdqm::utils rpcUtils;
68 
70 
72 
73  // Loop over DetUnit's
74  for (detUnitIt=rpcDigis->begin();detUnitIt!=rpcDigis->end();++detUnitIt){
75  const RPCDetId& id = (*detUnitIt).first;
76  const RPCRoll* roll = dynamic_cast<const RPCRoll* >( pDD->roll(id));
77  const RPCDigiCollection::Range& range = (*detUnitIt).second;
78  // std::cout <<" detector "<< id.region()<< std::endl;
79  std::ostringstream tag;
80  std::ostringstream name;
81  MonitorElement* me;
82 
83  //get roll name
84  RPCGeomServ RPCname(id);
85  std::string nameRoll = RPCname.name();
86  //get roll number
87  RPCGeomServ RPCnumber(id);
88  int nr = RPCnumber.chambernr();
89  //get segment (valid only if endcap)
90  RPCGeomServ RPCsegment(id);
91  int seg = RPCsegment.segment();
92 
93  // Loop over the digis of this DetUnit
94  for (RPCDigiCollection::const_iterator digiIt = range.first;digiIt!=range.second;++digiIt) {
95  if (digiIt->strip() < 1 || digiIt->strip() > roll->nstrips() )
96  edm::LogVerbatim ("rpcmonitorerror") <<" XXXX Problem with detector "<< id << ", strip # " << digiIt->strip();
97  else { //Loop on digi2
98  for (RPCDigiCollection::const_iterator digiIt2 = digiIt; digiIt2!=range.second; ++digiIt2) {
99  int dstrip = digiIt->strip() - digiIt2->strip();
100  int dbx = digiIt->bx() - digiIt2->bx();
101  if ( dstrip == 0 && abs(dbx) != 0 ) {
102  // std::cout <<" detector 3333 "<< id.region()<<" " << id.ring()<<std::endl;
103  me = dbe_->get(globalFolder_ + "/AfterPulseBxDiff");
104  if(!me) continue;
105  me->Fill(dbx);
106 
107  if (id.region()!=0){//Endcap
108  name.str("");
109  tag.str("");
110  tag << "AfterPulse_Ring_vs_Segment_Disk_" << id.region()*id.station();
111  name << "Endcap, After Pulse, Diff bx, Disk # " << id.region()*id.station();
112  me = dbe_->get(globalFolder_ + "/"+tag.str());
113  if (!me){
114  me = dbe_->book2D (tag.str(),name.str(),36,0.5,36.5, 3*numberOfRings_, 0.0, 3*numberOfRings_);
115 
116  rpcUtils.labelXAxisSegment(me);
117  rpcUtils.labelYAxisRing(me, numberOfRings_, true);
118 
119  }
120  int yBin;
121  (numberOfRings_ == 3 ? yBin= id.ring()*3-id.roll()+1 : yBin= (id.ring()-1)*3-id.roll()+1);
122  me->Fill(seg, yBin);
123  } else { // Barrel ( region == 0 ).
124 
125  name.str("");
126  tag.str("");
127  tag << "AfterPulse_Roll_vs_Sector_Wheel_" << std::setw(2) << std::setfill('+') << id.ring();
128  name << "Barrel, After Pulse, Diff. bx, Wheel # " << std::setw(2) << std::setfill('+') << id.ring();
129  me = dbe_->get(globalFolder_ + "/"+tag.str());
130  if (!me){
131  me = dbe_->book2D (tag.str(),name.str(),12,0.5,12.5,21,0.5,21.5);
132  rpcUtils.labelXAxisSector( me);
133  rpcUtils.labelYAxisRoll(me, 0, id.ring(), true);
134  }
135  me->Fill(id.sector(),nr);
136  }//Barrel
137  }
138  }
139  }
140  }
141  }
142 }
tuple yBin
Definition: cuy.py:891
int nstrips() const
Definition: RPCRoll.cc:46
#define abs(x)
Definition: mlp_lapack.h:159
void labelXAxisSegment(MonitorElement *myMe)
Definition: utils.h:251
void labelYAxisRoll(MonitorElement *myMe, int region, int ring, bool useRollInfo)
Definition: utils.h:269
edm::InputTag rpcDigiCollectionTag_
void Fill(long long x)
void labelYAxisRing(MonitorElement *myMe, int numberOfRings, bool useRollInfo)
Definition: utils.h:296
MonitorElement * get(const std::string &path) const
get ME from full pathname (e.g. &quot;my/long/dir/my_histo&quot;)
Definition: DQMStore.cc:1473
void labelXAxisSector(MonitorElement *myMe)
Definition: utils.h:236
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:361
const T & get() const
Definition: EventSetup.h:55
std::vector< DigiType >::const_iterator const_iterator
std::pair< const_iterator, const_iterator > Range
MonitorElement * book2D(const char *name, const char *title, int nchX, double lowX, double highX, int nchY, double lowY, double highY)
Book 2D histogram.
Definition: DQMStore.cc:850
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:434
void RPCMon_SS_Dbx_Global::beginJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 40 of file RPCMon_SS_Dbx_Global.cc.

References dbe_, and cppFunctionSkipper::operator.

40  {
41  edm::LogVerbatim ("rpcmonitorerror") << "[RPCMon_SS_Dbx_Global]: Begin job ";
43 }
void RPCMon_SS_Dbx_Global::beginRun ( const edm::Run r,
const edm::EventSetup c 
)
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 47 of file RPCMon_SS_Dbx_Global.cc.

References DQMStore::book1D(), dbe_, DQMStore::get(), MonitorElement::getName(), globalFolder_, DQMStore::removeElement(), and DQMStore::setCurrentFolder().

47  {
48  edm::LogVerbatim ("rpcmonitorerror") << "[RPCMon_SS_Dbx_Global]: Begin run";
49 
51 
52  MonitorElement* me;
53  me =0;
54  me = dbe_->get(globalFolder_ + "/AfterPulseBxDiff");
55  if ( 0!=me)
56  dbe_->removeElement(me->getName());
57  me = dbe_->book1D("AfterPulseBxDiff","After Pulse Bx Difference",13,-6.5,6.5);
58 }
const std::string & getName(void) const
get name of ME
MonitorElement * book1D(const char *name, const char *title, int nchX, double lowX, double highX)
Book 1D histogram.
Definition: DQMStore.cc:722
void removeElement(const std::string &name)
Definition: DQMStore.cc:2577
MonitorElement * get(const std::string &path) const
get ME from full pathname (e.g. &quot;my/long/dir/my_histo&quot;)
Definition: DQMStore.cc:1473
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:434
void RPCMon_SS_Dbx_Global::endJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 45 of file RPCMon_SS_Dbx_Global.cc.

45 {}

Member Data Documentation

DQMStore* RPCMon_SS_Dbx_Global::dbe_
private

Definition at line 31 of file RPCMon_SS_Dbx_Global.h.

Referenced by analyze(), beginJob(), beginRun(), and ~RPCMon_SS_Dbx_Global().

std::string RPCMon_SS_Dbx_Global::digiLabel_
private

Definition at line 28 of file RPCMon_SS_Dbx_Global.h.

Referenced by RPCMon_SS_Dbx_Global().

std::string RPCMon_SS_Dbx_Global::globalFolder_
private

Definition at line 28 of file RPCMon_SS_Dbx_Global.h.

Referenced by analyze(), beginRun(), and RPCMon_SS_Dbx_Global().

int RPCMon_SS_Dbx_Global::numberOfRings_
private

Definition at line 32 of file RPCMon_SS_Dbx_Global.h.

Referenced by analyze(), and RPCMon_SS_Dbx_Global().

std::string RPCMon_SS_Dbx_Global::rootFileName_
private

Definition at line 30 of file RPCMon_SS_Dbx_Global.h.

Referenced by RPCMon_SS_Dbx_Global().

edm::InputTag RPCMon_SS_Dbx_Global::rpcDigiCollectionTag_
private

Definition at line 33 of file RPCMon_SS_Dbx_Global.h.

Referenced by analyze().

bool RPCMon_SS_Dbx_Global::saveRootFile_
private

Definition at line 29 of file RPCMon_SS_Dbx_Global.h.

Referenced by RPCMon_SS_Dbx_Global().