#include <RPCDCSSummary.h>
Public Member Functions | |
RPCDCSSummary (const edm::ParameterSet &pset) | |
Constructor. | |
virtual | ~RPCDCSSummary () |
Destructor. | |
Private Member Functions | |
virtual void | analyze (const edm::Event &event, const edm::EventSetup &setup) |
virtual void | beginJob () |
virtual void | beginLuminosityBlock (const edm::LuminosityBlock &lumi, const edm::EventSetup &setup) |
void | beginRun (const edm::Run &, const edm::EventSetup &) |
virtual void | endJob () |
virtual void | endLuminosityBlock (const edm::LuminosityBlock &lumi, const edm::EventSetup &setup) |
Private Attributes | |
MonitorElement * | dcsDiskFractions [10] |
MonitorElement * | DCSMap_ |
MonitorElement * | dcsWheelFractions [5] |
std::pair< int, int > | FEDRange_ |
int | numberOfDisks_ |
int | NumberOfFeds_ |
DQMStore * | theDbe |
MonitorElement * | totalDCSFraction |
Definition at line 12 of file RPCDCSSummary.h.
RPCDCSSummary::RPCDCSSummary | ( | const edm::ParameterSet & | pset | ) |
Constructor.
Definition at line 15 of file RPCDCSSummary.cc.
References FEDRange_, edm::ParameterSet::getUntrackedParameter(), numberOfDisks_, and NumberOfFeds_.
{ numberOfDisks_ = ps.getUntrackedParameter<int>("NumberOfEndcapDisks", 3); FEDRange_.first = ps.getUntrackedParameter<unsigned int>("MinimumRPCFEDId", 790); FEDRange_.second = ps.getUntrackedParameter<unsigned int>("MaximumRPCFEDId", 792); NumberOfFeds_ =FEDRange_.second - FEDRange_.first +1; }
RPCDCSSummary::~RPCDCSSummary | ( | ) | [virtual] |
void RPCDCSSummary::analyze | ( | const edm::Event & | event, |
const edm::EventSetup & | setup | ||
) | [private, virtual] |
void RPCDCSSummary::beginJob | ( | void | ) | [private, virtual] |
void RPCDCSSummary::beginLuminosityBlock | ( | const edm::LuminosityBlock & | lumi, |
const edm::EventSetup & | setup | ||
) | [private, virtual] |
void RPCDCSSummary::beginRun | ( | const edm::Run & | r, |
const edm::EventSetup & | setup | ||
) | [private, virtual] |
Reimplemented from edm::EDAnalyzer.
Definition at line 29 of file RPCDCSSummary.cc.
References DQMStore::book2D(), DQMStore::bookFloat(), dcsDiskFractions, DCSMap_, dcsWheelFractions, f, FEDRange_, MonitorElement::Fill(), edm::EventSetup::find(), edm::eventsetup::heterocontainer::HCTypeTag::findType(), edm::EventSetup::get(), i, j, MessageLogger_cff::limit, numberOfDisks_, evf::evtn::offset(), cmsCodeRules::cppFunctionSkipper::operator, MonitorElement::setBinContent(), MonitorElement::setBinLabel(), DQMStore::setCurrentFolder(), hcal_dqm_sourceclient-file_cfg::streams, theDbe, and totalDCSFraction.
{ edm::eventsetup::EventSetupRecordKey recordKey(edm::eventsetup::EventSetupRecordKey::TypeTag::findType("RunInfoRcd")); int defaultValue = 1; if(0 != setup.find( recordKey ) ) { defaultValue = -1; //get fed summary information edm::ESHandle<RunInfo> sumFED; setup.get<RunInfoRcd>().get(sumFED); std::vector<int> FedsInIds= sumFED->m_fed_in; unsigned int f = 0; bool flag = false; while(!flag && f < FedsInIds.size()) { int fedID=FedsInIds[f]; //make sure fed id is in allowed range if(fedID>=FEDRange_.first && fedID<=FEDRange_.second) { defaultValue = 1; flag = true; } f++; } } // get the DQMStore theDbe = edm::Service<DQMStore>().operator->(); theDbe->setCurrentFolder("RPC/EventInfo"); // global fraction totalDCSFraction = theDbe->bookFloat("DCSSummary"); totalDCSFraction->Fill(defaultValue); DCSMap_ = theDbe->book2D( "DCSSummaryMap","RPC DCS Summary Map",15, -7.5, 7.5, 12, 0.5 ,12.5); //customize the 2d histo std::stringstream BinLabel; for (int i= 1 ; i<13; i++){ BinLabel.str(""); BinLabel<<"Sec"<<i; DCSMap_->setBinLabel(i,BinLabel.str(),2); } for(int i = -2; i<=2; i++){ BinLabel.str(""); BinLabel<<"Wheel"<<i; DCSMap_->setBinLabel((i+8),BinLabel.str(),1); } for(int i = 1; i<=numberOfDisks_; i++){ BinLabel.str(""); BinLabel<<"Disk"<<i; DCSMap_->setBinLabel((i+11),BinLabel.str(),1); BinLabel.str(""); BinLabel<<"Disk"<<-i; DCSMap_->setBinLabel((-i+5),BinLabel.str(),1); } //fill the histo with "1" --- just for the moment for(int i=1; i<=15; i++){ for (int j=1; j<=12; j++ ){ if(i==5 || i==11 || (j>6 && (i<6 || i>10))) DCSMap_->setBinContent(i,j,-1);//bins that not correspond to subdetector parts else DCSMap_->setBinContent(i,j,defaultValue); } } if(numberOfDisks_ < 4){ for (int j=1; j<=12; j++ ){ DCSMap_->setBinContent(1,j,-1);//bins that not correspond to subdetector parts DCSMap_->setBinContent(15,j,-1); } } // book the ME theDbe->setCurrentFolder("RPC/EventInfo/DCSContents"); int limit = numberOfDisks_; if(numberOfDisks_ < 2) limit = 2; for (int i = -1 * limit; i<= limit;i++ ){//loop on wheels and disks if (i>-3 && i<3){//wheels std::stringstream streams; streams << "RPC_Wheel" << i; dcsWheelFractions[i+2] = theDbe->bookFloat(streams.str()); dcsWheelFractions[i+2]->Fill(defaultValue); } if (i == 0 || i > numberOfDisks_ || i< (-1 * numberOfDisks_))continue; int offset = numberOfDisks_; if (i>0) offset --; //used to skip case equale to zero std::stringstream streams; streams << "RPC_Disk" << i; dcsDiskFractions[i+2] = theDbe->bookFloat(streams.str()); dcsDiskFractions[i+2]->Fill(defaultValue); } }
void RPCDCSSummary::endJob | ( | void | ) | [private, virtual] |
void RPCDCSSummary::endLuminosityBlock | ( | const edm::LuminosityBlock & | lumi, |
const edm::EventSetup & | setup | ||
) | [private, virtual] |
MonitorElement* RPCDCSSummary::dcsDiskFractions[10] [private] |
Definition at line 36 of file RPCDCSSummary.h.
Referenced by beginRun().
MonitorElement* RPCDCSSummary::DCSMap_ [private] |
Definition at line 33 of file RPCDCSSummary.h.
Referenced by beginRun().
MonitorElement* RPCDCSSummary::dcsWheelFractions[5] [private] |
Definition at line 35 of file RPCDCSSummary.h.
Referenced by beginRun().
std::pair<int, int> RPCDCSSummary::FEDRange_ [private] |
Definition at line 37 of file RPCDCSSummary.h.
Referenced by beginRun(), and RPCDCSSummary().
int RPCDCSSummary::numberOfDisks_ [private] |
Definition at line 38 of file RPCDCSSummary.h.
Referenced by beginRun(), and RPCDCSSummary().
int RPCDCSSummary::NumberOfFeds_ [private] |
Definition at line 39 of file RPCDCSSummary.h.
Referenced by RPCDCSSummary().
DQMStore* RPCDCSSummary::theDbe [private] |
Definition at line 32 of file RPCDCSSummary.h.
Referenced by beginRun().
MonitorElement* RPCDCSSummary::totalDCSFraction [private] |
Definition at line 34 of file RPCDCSSummary.h.
Referenced by beginRun().