CMS 3D CMS Logo

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

#include <SiPixelErrors/SiPixelErrorsDigisToCalibDigis/src/SiPixelErrorsDigisToCalibDigis.cc>

Inheritance diagram for SiPixelErrorsDigisToCalibDigis:
edm::EDAnalyzer edm::EDConsumerBase

Public Member Functions

MonitorElementbookDQMHistogram2D (uint32_t detid, std::string name, std::string title, int nchX, double lowX, double highX, int nchY, double lowY, double highY)
 
MonitorElementbookDQMHistoPlaquetteSummary2D (uint32_t detid, std::string name, std::string title)
 
bool setDQMDirectory (std::string dirName)
 
bool setDQMDirectory (uint32_t detID)
 
 SiPixelErrorsDigisToCalibDigis (const edm::ParameterSet &)
 
 ~SiPixelErrorsDigisToCalibDigis ()
 
- Public Member Functions inherited from edm::EDAnalyzer
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzer ()
 
ModuleDescription const & moduleDescription () const
 
std::string workerType () const
 
virtual ~EDAnalyzer ()
 
- Public Member Functions inherited from edm::EDConsumerBase
 EDConsumerBase ()
 
ProductHolderIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
std::vector
< ProductHolderIndexAndSkipBit >
const & 
itemsToGetFromEvent () const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesDependentUpon (const std::string &iProcessName, std::vector< const char * > &oModuleLabels) const
 
bool registeredToConsume (ProductHolderIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Protected Attributes

edm::ESHandle< TrackerGeometrygeom_
 

Private Member Functions

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

Private Attributes

bool createOutputFile_
 
DQMStoredaqBE_
 
SiPixelFolderOrganizerfolderMaker_
 
std::string outputFilename_
 
std::map< uint32_t,
MonitorElement * > 
SiPixelErrorsDigisToCalibDigis_2DErrorInformation_
 
edm::InputTag siPixelProducerLabel_
 
MonitorElementtemp
 
SiPixelHistogramIdtheHistogramIdWorker_
 
edm::EDGetTokenT
< edm::DetSetVector
< SiPixelCalibDigiError > > 
tPixelCalibDigiError
 

Additional Inherited Members

- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
- 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::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

 class SiPixelErrorsDigisToCalibDigis

Description: Create monitorElements for the Errors in created in the reduction of digis to calibDigis

Description: <one line="" class="" summary>="">

Implementation: <Notes on="" implementation>="">

Definition at line 51 of file SiPixelErrorsDigisToCalibDigis.h.

Constructor & Destructor Documentation

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

Definition at line 45 of file SiPixelErrorsDigisToCalibDigis.cc.

References createOutputFile_, daqBE_, folderMaker_, edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), outputFilename_, siPixelProducerLabel_, AlCaHLTBitMon_QueryRunRegistry::string, and tPixelCalibDigiError.

47 {
48 
49  siPixelProducerLabel_ = iConfig.getParameter<edm::InputTag>("SiPixelProducerLabelTag");
50  createOutputFile_ = iConfig.getUntrackedParameter<bool>("saveFile",false);
51  outputFilename_ = iConfig.getParameter<std::string>("outputFilename");
54 
55  tPixelCalibDigiError = consumes <edm::DetSetVector<SiPixelCalibDigiError> >(siPixelProducerLabel_);
56 
57 // std::cout<<"siPixelProducerLabel_ = "<<siPixelProducerLabel_<<std::endl;
58 // std::cout<<"createOutputFile_= "<< createOutputFile_<<std::endl;
59 // std::cout<<"outpuFilename_= "<< outputFilename_<< std::endl;
60 }
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
edm::EDGetTokenT< edm::DetSetVector< SiPixelCalibDigiError > > tPixelCalibDigiError
SiPixelErrorsDigisToCalibDigis::~SiPixelErrorsDigisToCalibDigis ( )

Definition at line 63 of file SiPixelErrorsDigisToCalibDigis.cc.

64 {
65 
66  // do anything here that needs to be done at desctruction time
67  // (e.g. close files, deallocate resources etc.)
68 
69 }

Member Function Documentation

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

Implements edm::EDAnalyzer.

Definition at line 78 of file SiPixelErrorsDigisToCalibDigis.cc.

References edm::DetSet< T >::begin(), bookDQMHistoPlaquetteSummary2D(), edm::DetSet< T >::end(), MonitorElement::Fill(), first, geom_, edm::EventSetup::get(), edm::Event::getByToken(), edm::InputTag::label(), setDQMDirectory(), SiPixelErrorsDigisToCalibDigis_2DErrorInformation_, siPixelProducerLabel_, theHistogramIdWorker_, and tPixelCalibDigiError.

79 {
80  using namespace edm;
81 
82  static int first(1);
83  if (1 == first) {
84  first = 0;
85  iSetup.get<TrackerDigiGeometryRecord>().get( geom_ );
87  }
88 
90  iEvent.getByToken(tPixelCalibDigiError, thePlaquettes);
91  // iEvent.getByLabel("siPixelCalibDigis", thePlaquettes);
92 
93 
95 
96 
97  for (digiIter=thePlaquettes->begin(); digiIter!=thePlaquettes->end(); digiIter++)
98  {
99  uint32_t detId = digiIter->id;
100 
102  //loop over pixel errors pulsed in the current plaquette
103 
104  MonitorElement* temp_;
105 
106  std::map<uint32_t, MonitorElement*>::iterator mapIterator = SiPixelErrorsDigisToCalibDigis_2DErrorInformation_.find(detId);
107 
108  if (digiIter->begin() != digiIter->end()) {
109  if ( mapIterator == SiPixelErrorsDigisToCalibDigis_2DErrorInformation_.end() )
110  {
111 // std::cout << "This is the beginning of an error 2d histo booking: "<<std::endl;
112  setDQMDirectory(detId);
113  temp_ = bookDQMHistoPlaquetteSummary2D(detId, "SiPixelErrorsCalibDigis", "SiPixelErrorsDigisToCalibDigis");
114  SiPixelErrorsDigisToCalibDigis_2DErrorInformation_.insert( std::make_pair(detId,temp_));
115  }
116  else
117  {
118 // std::cout << "This one was already booked."<<std::endl;
119  temp_ = (*mapIterator).second;
120  }
121 
122  for(ipix=digiIter->begin(); ipix!=digiIter->end(); ++ipix)
123  {
124  temp_->Fill(ipix->getCol(), ipix->getRow());
125 // std::cout << "detId: " << detId << " " << ipix->getRow() << " " << ipix->getCol() << std::endl;
126  }
127 
128  } // end of the if statement asking if the plaquette in question has any errors in it
129 
130  }// end of the for loop that goes through all plaquettes
131 
132 }
iterator end()
Definition: DetSet.h:60
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:434
void Fill(long long x)
bool first
Definition: L1TdeRCT.cc:75
std::map< uint32_t, MonitorElement * > SiPixelErrorsDigisToCalibDigis_2DErrorInformation_
iterator begin()
Definition: DetSet.h:59
const T & get() const
Definition: EventSetup.h:55
edm::EDGetTokenT< edm::DetSetVector< SiPixelCalibDigiError > > tPixelCalibDigiError
std::string const & label() const
Definition: InputTag.h:42
edm::ESHandle< TrackerGeometry > geom_
MonitorElement * bookDQMHistoPlaquetteSummary2D(uint32_t detid, std::string name, std::string title)
collection_type::const_iterator const_iterator
Definition: DetSet.h:33
collection_type::const_iterator const_iterator
Definition: DetSetVector.h:106
void SiPixelErrorsDigisToCalibDigis::beginJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 137 of file SiPixelErrorsDigisToCalibDigis.cc.

138 {
139 
140 }
MonitorElement * SiPixelErrorsDigisToCalibDigis::bookDQMHistogram2D ( uint32_t  detid,
std::string  name,
std::string  title,
int  nchX,
double  lowX,
double  highX,
int  nchY,
double  lowY,
double  highY 
)

Definition at line 155 of file SiPixelErrorsDigisToCalibDigis.cc.

References DQMStore::book2D(), daqBE_, SiPixelHistogramId::setHistoId(), AlCaHLTBitMon_QueryRunRegistry::string, and theHistogramIdWorker_.

156 {
158  return daqBE_->book2D(hid, title, nchX, lowX, highX, nchY, lowY, highY);
159 }
std::string setHistoId(std::string variable, uint32_t &rawId)
Set Histogram Id.
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:1070
MonitorElement * SiPixelErrorsDigisToCalibDigis::bookDQMHistoPlaquetteSummary2D ( uint32_t  detid,
std::string  name,
std::string  title 
)

Definition at line 161 of file SiPixelErrorsDigisToCalibDigis.cc.

References DQMStore::book2D(), daqBE_, geom_, TrackerGeometry::idToDet(), PixelTopology::ncolumns(), PixelTopology::nrows(), SiPixelHistogramId::setHistoId(), PixelGeomDetUnit::specificTopology(), AlCaHLTBitMon_QueryRunRegistry::string, and theHistogramIdWorker_.

Referenced by analyze().

161  {
162 
163  DetId detId(detid);
164  const TrackerGeometry &theTracker(*geom_);
165  const PixelGeomDetUnit *theGeomDet = dynamic_cast<const PixelGeomDetUnit*> ( theTracker.idToDet(detId) );
166  int maxcol = theGeomDet->specificTopology().ncolumns();
167  int maxrow = theGeomDet->specificTopology().nrows();
168 
170  return daqBE_->book2D(hid,title,maxcol,0,maxcol,maxrow,0,maxrow);
171 }
virtual int ncolumns() const =0
virtual int nrows() const =0
std::string setHistoId(std::string variable, uint32_t &rawId)
Set Histogram Id.
Definition: DetId.h:18
virtual const PixelTopology & specificTopology() const
Returns a reference to the pixel proxy topology.
edm::ESHandle< TrackerGeometry > geom_
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:1070
void SiPixelErrorsDigisToCalibDigis::endJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 144 of file SiPixelErrorsDigisToCalibDigis.cc.

References createOutputFile_, outputFilename_, and cuy::save.

144  {
145 
146  if (!outputFilename_.empty() && createOutputFile_)
147  {
148  edm::LogInfo("SiPixelErrorCalibDigis") << "Writing ROOT file to: " << outputFilename_ << std::endl;
150  }
151 }
list save
Definition: cuy.py:1163
bool SiPixelErrorsDigisToCalibDigis::setDQMDirectory ( std::string  dirName)

Definition at line 173 of file SiPixelErrorsDigisToCalibDigis.cc.

References daqBE_, DQMStore::dirExists(), and DQMStore::setCurrentFolder().

Referenced by analyze().

174 {
176  return daqBE_->dirExists(dirName);
177 }
bool dirExists(const std::string &path) const
true if directory exists
Definition: DQMStore.cc:720
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:655
bool SiPixelErrorsDigisToCalibDigis::setDQMDirectory ( uint32_t  detID)

Definition at line 179 of file SiPixelErrorsDigisToCalibDigis.cc.

References folderMaker_, and SiPixelFolderOrganizer::setModuleFolder().

180 {
181  return folderMaker_->setModuleFolder(detID,0);
182 }
bool setModuleFolder(const uint32_t &rawdetid=0, int type=0, bool isUpgrade=false)
Set folder name for a module or plaquette.

Member Data Documentation

bool SiPixelErrorsDigisToCalibDigis::createOutputFile_
private

Definition at line 81 of file SiPixelErrorsDigisToCalibDigis.h.

Referenced by endJob(), and SiPixelErrorsDigisToCalibDigis().

DQMStore* SiPixelErrorsDigisToCalibDigis::daqBE_
private
SiPixelFolderOrganizer* SiPixelErrorsDigisToCalibDigis::folderMaker_
private
edm::ESHandle<TrackerGeometry> SiPixelErrorsDigisToCalibDigis::geom_
protected

Definition at line 63 of file SiPixelErrorsDigisToCalibDigis.h.

Referenced by analyze(), and bookDQMHistoPlaquetteSummary2D().

std::string SiPixelErrorsDigisToCalibDigis::outputFilename_
private

Definition at line 80 of file SiPixelErrorsDigisToCalibDigis.h.

Referenced by endJob(), and SiPixelErrorsDigisToCalibDigis().

std::map<uint32_t, MonitorElement*> SiPixelErrorsDigisToCalibDigis::SiPixelErrorsDigisToCalibDigis_2DErrorInformation_
private

Definition at line 84 of file SiPixelErrorsDigisToCalibDigis.h.

Referenced by analyze().

edm::InputTag SiPixelErrorsDigisToCalibDigis::siPixelProducerLabel_
private

Definition at line 75 of file SiPixelErrorsDigisToCalibDigis.h.

Referenced by analyze(), and SiPixelErrorsDigisToCalibDigis().

MonitorElement* SiPixelErrorsDigisToCalibDigis::temp
private

Definition at line 86 of file SiPixelErrorsDigisToCalibDigis.h.

SiPixelHistogramId* SiPixelErrorsDigisToCalibDigis::theHistogramIdWorker_
private
edm::EDGetTokenT<edm::DetSetVector<SiPixelCalibDigiError> > SiPixelErrorsDigisToCalibDigis::tPixelCalibDigiError
private

Definition at line 76 of file SiPixelErrorsDigisToCalibDigis.h.

Referenced by analyze(), and SiPixelErrorsDigisToCalibDigis().