CMS 3D CMS Logo

List of all members | Public Member Functions | Protected Member Functions | Private Attributes
SiStripCommissioningOfflineDbClient Class Reference

Class which reads a root file containing "commissioning histograms", analyzes the histograms to extract "monitorables", creates summary histograms, and uploads to DB. More...

#include <SiStripCommissioningOfflineDbClient.h>

Inheritance diagram for SiStripCommissioningOfflineDbClient:
SiStripCommissioningOfflineClient edm::EDAnalyzer edm::EDConsumerBase

Public Member Functions

 SiStripCommissioningOfflineDbClient (const edm::ParameterSet &)
 
 ~SiStripCommissioningOfflineDbClient () override
 
- Public Member Functions inherited from SiStripCommissioningOfflineClient
void analyze (const edm::Event &, const edm::EventSetup &) override
 
void beginRun (const edm::Run &, const edm::EventSetup &) override
 
void endJob () override
 
 SiStripCommissioningOfflineClient (const edm::ParameterSet &)
 
 ~SiStripCommissioningOfflineClient () override
 
- Public Member Functions inherited from edm::EDAnalyzer
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzer ()
 
SerialTaskQueueglobalLuminosityBlocksQueue ()
 
SerialTaskQueueglobalRunsQueue ()
 
ModuleDescription const & moduleDescription () const
 
std::string workerType () const
 
 ~EDAnalyzer () override
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase &&)=default
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
ESProxyIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Protected Member Functions

void createHistos (const edm::ParameterSet &, const edm::EventSetup &) override
 
void uploadToConfigDb () override
 
- Protected Member Functions inherited from SiStripCommissioningOfflineClient
virtual void setInputFiles (std::vector< std::string > &, const std::string, const std::string, uint32_t, bool)
 
- Protected Member Functions inherited from edm::EDConsumerBase
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (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 ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes ()
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes (ESInputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 

Private Attributes

bool uploadAnal_
 
bool uploadConf_
 
bool uploadToDb_
 

Additional Inherited Members

- Public Types inherited from SiStripCommissioningOfflineClient
typedef dqm::harvesting::DQMStore DQMStore
 
typedef dqm::harvesting::MonitorElement MonitorElement
 
- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::EDAnalyzer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
static bool wantsGlobalLuminosityBlocks ()
 
static bool wantsGlobalRuns ()
 
static bool wantsStreamLuminosityBlocks ()
 
static bool wantsStreamRuns ()
 
- Protected Types inherited from SiStripCommissioningOfflineClient
typedef std::vector< TH1 * > Histos
 
typedef std::map< uint32_t, HistosHistosMap
 
- Protected Attributes inherited from SiStripCommissioningOfflineClient
bool analyzeHistos_
 
DQMStorebei_
 
bool clientHistos_
 
bool collateHistos_
 
bool createSummaryPlots_
 
CommissioningHistogramshistos_
 
std::vector< std::string > inputFiles_
 
HistosMap map_
 
std::string outputFileName_
 
edm::ParameterSet parameters_
 
std::string partitionName_
 
std::vector< SummaryPlotplots_
 
uint32_t runNumber_
 
sistrip::RunType runType_
 
bool uploadToDb_
 
std::string xmlFile_
 

Detailed Description

Class which reads a root file containing "commissioning histograms", analyzes the histograms to extract "monitorables", creates summary histograms, and uploads to DB.

Author
R.Bainbridge, M.Wingham

Definition at line 17 of file SiStripCommissioningOfflineDbClient.h.

Constructor & Destructor Documentation

◆ SiStripCommissioningOfflineDbClient()

SiStripCommissioningOfflineDbClient::SiStripCommissioningOfflineDbClient ( const edm::ParameterSet pset)

Definition at line 27 of file SiStripCommissioningOfflineDbClient.cc.

29  uploadAnal_(pset.getUntrackedParameter<bool>("UploadAnalyses", false)),
30  uploadConf_(pset.getUntrackedParameter<bool>("UploadHwConfig", false)) {
31  LogTrace(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
32  << " Constructing object...";
33  if (!uploadConf_) {
34  edm::LogWarning(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
35  << " ===> TEST only! No hardware configurations"
36  << " will be uploaded to the DB...";
37  }
38  if (!uploadAnal_) {
39  edm::LogWarning(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
40  << " ===> TEST only! No analysis descriptions"
41  << " will be uploaded to the DB...";
42  }
43 }

References LogTrace, sistrip::mlDqmClient_, uploadAnal_, and uploadConf_.

◆ ~SiStripCommissioningOfflineDbClient()

SiStripCommissioningOfflineDbClient::~SiStripCommissioningOfflineDbClient ( )
override

Definition at line 47 of file SiStripCommissioningOfflineDbClient.cc.

47  {
48  LogTrace(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
49  << " Destructing object...";
50 }

References LogTrace, and sistrip::mlDqmClient_.

Member Function Documentation

◆ createHistos()

void SiStripCommissioningOfflineDbClient::createHistos ( const edm::ParameterSet pset,
const edm::EventSetup setup 
)
overrideprotectedvirtual

Reimplemented from SiStripCommissioningOfflineClient.

Definition at line 54 of file SiStripCommissioningOfflineDbClient.cc.

54  {
55  // Check pointer
56  if (histos_) {
57  edm::LogError(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
58  << " CommissioningHistogram object already exists!"
59  << " Aborting...";
60  return;
61  }
62 
63  // Check pointer to BEI
64  // is this needed here? bei_ = edm::Service<DQMStore>().operator->();
65  if (!bei_) {
66  edm::LogError(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
67  << " NULL pointer to DQMStore!";
68  return;
69  }
70 
71  // Create DB connection
72  SiStripConfigDb* db = edm::Service<SiStripConfigDb>().operator->(); //@@ NOT GUARANTEED TO BE THREAD SAFE!
73  LogTrace(mlCabling_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
74  << " Nota bene: using the SiStripConfigDb API"
75  << " as a \"service\" does not presently guarantee"
76  << " thread-safe behaviour!...";
77 
78  // Check DB connection
79  if (!db) {
80  edm::LogError(mlCabling_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
81  << " NULL pointer to SiStripConfigDb!"
82  << " Aborting...";
83  return;
84  }
85 
86  // Create corresponding "commissioning histograms" object
89  } else if (runType_ == sistrip::APV_TIMING) {
91  } else if (runType_ == sistrip::OPTO_SCAN) {
93  } else if (runType_ == sistrip::VPSP_SCAN) {
95  } else if (runType_ == sistrip::PEDESTALS) {
97  } else if (runType_ == sistrip::PEDS_ONLY) {
99  } else if (runType_ == sistrip::PEDS_FULL_NOISE) {
101  } else if (runType_ == sistrip::NOISE) {
103  } else if (runType_ == sistrip::APV_LATENCY) {
105  } else if (runType_ == sistrip::FINE_DELAY) {
110  } else if (runType_ == sistrip::DAQ_SCOPE_MODE) {
112  } else if (runType_ == sistrip::UNDEFINED_RUN_TYPE) {
113  histos_ = nullptr;
114  edm::LogError(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
115  << " Undefined run type!";
116  return;
117  } else if (runType_ == sistrip::UNKNOWN_RUN_TYPE) {
118  histos_ = nullptr;
119  edm::LogError(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
120  << " Unknown run type!";
121  return;
122  }
124 
125  CommissioningHistosUsingDb* tmp = dynamic_cast<CommissioningHistosUsingDb*>(histos_);
126  if (tmp) {
127  tmp->doUploadConf(uploadConf_);
128  tmp->doUploadAnal(uploadAnal_);
129  std::stringstream ss;
130  ss << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]" << std::endl
131  << " Uploading hardware configurations? : " << (tmp->doUploadConf() ? "true" : "false") << std::endl
132  << " Uploading calibrations from analysis? : " << (tmp->doUploadAnal() ? "true" : "false") << std::endl;
133  edm::LogVerbatim(mlDqmClient_) << ss.str();
134  } else {
135  edm::LogError(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
136  << " NULL pointer to CommissioningHistosUsingDb!";
137  }
138 }

References sistrip::APV_LATENCY, sistrip::APV_TIMING, SiStripCommissioningOfflineClient::bei_, sistrip::CALIBRATION, sistrip::CALIBRATION_DECO, sistrip::CALIBRATION_SCAN, sistrip::CALIBRATION_SCAN_DECO, CommissioningHistograms::configure(), sistrip::DAQ_SCOPE_MODE, dqmiodatasetharvest::db, sistrip::FAST_CABLING, sistrip::FINE_DELAY, SiStripCommissioningOfflineClient::histos_, LogTrace, sistrip::mlCabling_, sistrip::mlDqmClient_, sistrip::NOISE, sistrip::OPTO_SCAN, sistrip::PEDESTALS, sistrip::PEDS_FULL_NOISE, sistrip::PEDS_ONLY, muonDTDigis_cfi::pset, SiStripCommissioningOfflineClient::runType_, singleTopDQM_cfi::setup, contentValuesCheck::ss, createJobs::tmp, sistrip::UNDEFINED_RUN_TYPE, sistrip::UNKNOWN_RUN_TYPE, uploadAnal_, uploadConf_, and sistrip::VPSP_SCAN.

◆ uploadToConfigDb()

void SiStripCommissioningOfflineDbClient::uploadToConfigDb ( )
overrideprotectedvirtual

Reimplemented from SiStripCommissioningOfflineClient.

Definition at line 142 of file SiStripCommissioningOfflineDbClient.cc.

142  {
143  edm::LogVerbatim(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
144  << " Uploading parameters to database...";
145  CommissioningHistosUsingDb* tmp = dynamic_cast<CommissioningHistosUsingDb*>(histos_);
146  if (tmp) {
147  tmp->uploadToConfigDb();
148  edm::LogVerbatim(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
149  << " Uploaded parameters to database!";
150  } else {
151  edm::LogError(mlDqmClient_) << "[SiStripCommissioningOfflineDbClient::" << __func__ << "]"
152  << " NULL pointer to CommissioningHistosUsingDb object!"
153  << " Upload aborted!...";
154  }
155 }

References SiStripCommissioningOfflineClient::histos_, sistrip::mlDqmClient_, and createJobs::tmp.

Member Data Documentation

◆ uploadAnal_

bool SiStripCommissioningOfflineDbClient::uploadAnal_
private

◆ uploadConf_

bool SiStripCommissioningOfflineDbClient::uploadConf_
private

◆ uploadToDb_

bool SiStripCommissioningOfflineDbClient::uploadToDb_
private

Definition at line 29 of file SiStripCommissioningOfflineDbClient.h.

sistrip::CALIBRATION_SCAN
Definition: ConstantsForRunType.h:87
SiStripCommissioningOfflineClient::SiStripCommissioningOfflineClient
SiStripCommissioningOfflineClient(const edm::ParameterSet &)
Definition: SiStripCommissioningOfflineClient.cc:36
DaqScopeModeHistosUsingDb
Definition: DaqScopeModeHistosUsingDb.h:7
sistrip::DAQ_SCOPE_MODE
Definition: ConstantsForRunType.h:83
sistrip::CALIBRATION
Definition: ConstantsForRunType.h:73
sistrip::PEDS_FULL_NOISE
Definition: ConstantsForRunType.h:92
sistrip::VPSP_SCAN
Definition: ConstantsForRunType.h:82
sistrip::FAST_CABLING
Definition: ConstantsForRunType.h:89
sistrip::APV_TIMING
Definition: ConstantsForRunType.h:75
SiStripCommissioningOfflineClient::runType_
sistrip::RunType runType_
Definition: SiStripCommissioningOfflineClient.h:78
FastFedCablingHistosUsingDb
Definition: FastFedCablingHistosUsingDb.h:8
VpspScanHistosUsingDb
Definition: VpspScanHistosUsingDb.h:8
CalibrationHistosUsingDb
Definition: CalibrationHistosUsingDb.h:13
sistrip::OPTO_SCAN
Definition: ConstantsForRunType.h:74
createJobs.tmp
tmp
align.sh
Definition: createJobs.py:716
CommissioningHistosUsingDb
Definition: CommissioningHistosUsingDb.h:16
sistrip::mlDqmClient_
static const char mlDqmClient_[]
Definition: ConstantsForLogger.h:19
singleTopDQM_cfi.setup
setup
Definition: singleTopDQM_cfi.py:37
SiStripCommissioningOfflineClient::histos_
CommissioningHistograms * histos_
Definition: SiStripCommissioningOfflineClient.h:51
SiStripCommissioningOfflineDbClient::uploadConf_
bool uploadConf_
Definition: SiStripCommissioningOfflineDbClient.h:33
sistrip::FINE_DELAY
Definition: ConstantsForRunType.h:85
dqmiodatasetharvest.db
db
Definition: dqmiodatasetharvest.py:119
contentValuesCheck.ss
ss
Definition: contentValuesCheck.py:33
SiStripConfigDb
An interface class to the DeviceFactory.
Definition: SiStripConfigDb.h:47
CommissioningHistograms::configure
virtual void configure(const edm::ParameterSet &, const edm::EventSetup &)
Definition: CommissioningHistograms.h:37
edm::LogWarning
Definition: MessageLogger.h:141
sistrip::mlCabling_
static const char mlCabling_[]
Definition: ConstantsForLogger.h:14
sistrip::CALIBRATION_DECO
Definition: ConstantsForRunType.h:93
edm::LogError
Definition: MessageLogger.h:183
sistrip::PEDESTALS
Definition: ConstantsForRunType.h:72
sistrip::UNKNOWN_RUN_TYPE
Definition: ConstantsForRunType.h:94
PedsOnlyHistosUsingDb
Definition: PedsOnlyHistosUsingDb.h:8
edm::Service< SiStripConfigDb >
edm::LogVerbatim
Definition: MessageLogger.h:297
sistrip::PEDS_ONLY
Definition: ConstantsForRunType.h:90
sistrip::CALIBRATION_SCAN_DECO
Definition: ConstantsForRunType.h:88
sistrip::APV_LATENCY
Definition: ConstantsForRunType.h:76
sistrip::UNDEFINED_RUN_TYPE
Definition: ConstantsForRunType.h:95
LatencyHistosUsingDb
Definition: LatencyHistosUsingDb.h:11
sistrip::NOISE
Definition: ConstantsForRunType.h:91
PedsFullNoiseHistosUsingDb
Definition: PedsFullNoiseHistosUsingDb.h:8
PedestalsHistosUsingDb
Definition: PedestalsHistosUsingDb.h:8
OptoScanHistosUsingDb
Definition: OptoScanHistosUsingDb.h:8
LogTrace
#define LogTrace(id)
Definition: MessageLogger.h:671
NoiseHistosUsingDb
Definition: NoiseHistosUsingDb.h:8
SiStripCommissioningOfflineClient::bei_
DQMStore * bei_
Definition: SiStripCommissioningOfflineClient.h:48
ApvTimingHistosUsingDb
Definition: ApvTimingHistosUsingDb.h:8
FineDelayHistosUsingDb
Definition: FineDelayHistosUsingDb.h:13
SiStripCommissioningOfflineDbClient::uploadAnal_
bool uploadAnal_
Definition: SiStripCommissioningOfflineDbClient.h:31
muonDTDigis_cfi.pset
pset
Definition: muonDTDigis_cfi.py:27