CMS 3D CMS Logo

List of all members | Classes | Public Types | Public Member Functions | Private Attributes
EDMtoMEConverter Class Reference

#include <EDMtoMEConverter.h>

Inheritance diagram for EDMtoMEConverter:
edm::one::EDProducer< edm::one::WatchRuns, edm::one::WatchLuminosityBlocks, edm::one::SharedResources, edm::EndLuminosityBlockProducer, edm::EndRunProducer > edm::one::EDProducerBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Classes

class  Tokens
 

Public Types

typedef dqm::legacy::DQMStore DQMStore
 
typedef dqm::legacy::MonitorElement MonitorElement
 
using TagList = std::vector< uint32_t >
 
- Public Types inherited from edm::one::EDProducerBase
typedef EDProducerBase ModuleType
 
- Public Types inherited from edm::ProducerBase
using ModuleToResolverIndicies = std::unordered_multimap< std::string, std::tuple< edm::TypeID const *, const char *, edm::ProductResolverIndex >>
 
typedef ProductRegistryHelper::TypeLabelList TypeLabelList
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 

Public Member Functions

void beginJob () final
 
void beginLuminosityBlock (const edm::LuminosityBlock &, const edm::EventSetup &) final
 
void beginRun (const edm::Run &, const edm::EventSetup &) final
 
 EDMtoMEConverter (const edm::ParameterSet &)
 
void endJob () final
 
void endLuminosityBlock (const edm::LuminosityBlock &, const edm::EventSetup &) final
 
void endLuminosityBlockProduce (edm::LuminosityBlock &, edm::EventSetup const &) override
 
void endRun (const edm::Run &, const edm::EventSetup &) final
 
void endRunProduce (edm::Run &run, edm::EventSetup const &setup) override
 
template<class T >
void getData (DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, T &iGetFrom)
 
void produce (edm::Event &, edm::EventSetup const &) final
 
 ~EDMtoMEConverter () override
 
- Public Member Functions inherited from edm::one::EDProducer< edm::one::WatchRuns, edm::one::WatchLuminosityBlocks, edm::one::SharedResources, edm::EndLuminosityBlockProducer, edm::EndRunProducer >
 EDProducer ()=default
 
SerialTaskQueueglobalLuminosityBlocksQueue () final
 
SerialTaskQueueglobalRunsQueue () final
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndRuns () const final
 
bool wantsGlobalLuminosityBlocks () const final
 
bool wantsGlobalRuns () const final
 
- Public Member Functions inherited from edm::one::EDProducerBase
 EDProducerBase ()
 
ModuleDescription const & moduleDescription () const
 
bool wantsStreamLuminosityBlocks () const
 
bool wantsStreamRuns () const
 
 ~EDProducerBase () override
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector< edm::ProductResolverIndex > const & indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
std::vector< edm::ProductResolverIndex > const & putTokenIndexToProductResolverIndex () const
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription const &)> registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, ModuleToResolverIndicies const &iIndicies, std::string const &moduleLabel)
 
 ~ProducerBase () noexcept(false) 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 const &)=delete
 
 EDConsumerBase (EDConsumerBase &&)=default
 
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
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
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)
 

Private Attributes

bool convertOnEndLumi
 
bool convertOnEndRun
 
edm::EDPutTokenT< DQMTokendqmLumiToken_
 
edm::EDPutTokenT< DQMTokendqmRunToken_
 
int frequency
 
std::string name
 
std::tuple< Tokens< TH1F >, Tokens< TH1S >, Tokens< TH1D >, Tokens< TH2F >, Tokens< TH2S >, Tokens< TH2D >, Tokens< TH3F >, Tokens< TProfile >, Tokens< TProfile2D >, Tokens< double >, Tokens< int >, Tokens< long long >, Tokens< TString > > tokens_
 
int verbosity
 

Additional Inherited Members

- Static Public Member Functions inherited from edm::one::EDProducerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::ProducerBase
ProducesCollector producesCollector ()
 
- 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 ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes ()
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes (ESInputTag const &tag)
 
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 to take dqm monitor elements and convert into a ROOT dataformat stored in Run tree of edm file

Author
M. Strang SUNY-Buffalo

Definition at line 51 of file EDMtoMEConverter.h.

Member Typedef Documentation

Definition at line 57 of file EDMtoMEConverter.h.

Definition at line 58 of file EDMtoMEConverter.h.

using EDMtoMEConverter::TagList = std::vector<uint32_t>

Definition at line 77 of file EDMtoMEConverter.h.

Constructor & Destructor Documentation

EDMtoMEConverter::EDMtoMEConverter ( const edm::ParameterSet iPSet)
explicit

Definition at line 255 of file EDMtoMEConverter.cc.

References constexpr, edm::EDConsumerBase::consumesCollector(), convertOnEndLumi, convertOnEndRun, dqmLumiToken_, dqmRunToken_, frequency, edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), EDMtoMEConverter_cfi::lumiInputTag, name, EDMtoMEConverter_cfi::runInputTag, AlCaHLTBitMon_QueryRunRegistry::string, tokens_, verbosity, and ~EDMtoMEConverter().

255  : verbosity(0), frequency(0) {
256  const edm::InputTag &runInputTag = iPSet.getParameter<edm::InputTag>("runInputTag");
257  const edm::InputTag &lumiInputTag = iPSet.getParameter<edm::InputTag>("lumiInputTag");
259 
260  for_each(tokens_, [&](auto &tok) { tok.set(runInputTag, lumiInputTag, iC); });
261 
262  constexpr char MsgLoggerCat[] = "EDMtoMEConverter_EDMtoMEConverter";
263 
264  // get information from parameter set
265  name = iPSet.getUntrackedParameter<std::string>("Name");
266  verbosity = iPSet.getUntrackedParameter<int>("Verbosity");
267  frequency = iPSet.getUntrackedParameter<int>("Frequency");
268 
269  convertOnEndLumi = iPSet.getUntrackedParameter<bool>("convertOnEndLumi", true);
270  convertOnEndRun = iPSet.getUntrackedParameter<bool>("convertOnEndRun", true);
271 
272  // use value of first digit to determine default output level (inclusive)
273  // 0 is none, 1 is basic, 2 is fill output, 3 is gather output
274  verbosity %= 10;
275 
276  // print out Parameter Set information being used
277  if (verbosity >= 0) {
278  edm::LogInfo(MsgLoggerCat) << "\n===============================\n"
279  << "Initialized as EDAnalyzer with parameter values:\n"
280  << " Name = " << name << "\n"
281  << " Verbosity = " << verbosity << "\n"
282  << " Frequency = " << frequency << "\n"
283  << "===============================\n";
284  }
285 
286  assert(sizeof(int64_t) == sizeof(long long));
287  usesResource("DQMStore");
288 
289  dqmLumiToken_ = produces<DQMToken, edm::Transition::EndLuminosityBlock>("endLumi");
290  dqmRunToken_ = produces<DQMToken, edm::Transition::EndRun>("endRun");
291 } // end constructor
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
ConsumesCollector consumesCollector()
Use a ConsumesCollector to gather consumes information from helper functions.
edm::EDPutTokenT< DQMToken > dqmRunToken_
std::tuple< Tokens< TH1F >, Tokens< TH1S >, Tokens< TH1D >, Tokens< TH2F >, Tokens< TH2S >, Tokens< TH2D >, Tokens< TH3F >, Tokens< TProfile >, Tokens< TProfile2D >, Tokens< double >, Tokens< int >, Tokens< long long >, Tokens< TString > > tokens_
edm::EDPutTokenT< DQMToken > dqmLumiToken_
#define constexpr
EDMtoMEConverter::~EDMtoMEConverter ( )
overridedefault

Referenced by EDMtoMEConverter().

Member Function Documentation

void EDMtoMEConverter::beginJob ( void  )
inlinefinalvirtual

Reimplemented from edm::one::EDProducerBase.

Definition at line 63 of file EDMtoMEConverter.h.

63 {};
void EDMtoMEConverter::beginLuminosityBlock ( const edm::LuminosityBlock ,
const edm::EventSetup  
)
inlinefinal

Definition at line 67 of file EDMtoMEConverter.h.

67 {};
void EDMtoMEConverter::beginRun ( const edm::Run ,
const edm::EventSetup  
)
inlinefinal

Definition at line 65 of file EDMtoMEConverter.h.

65 {};
void EDMtoMEConverter::endJob ( void  )
inlinefinalvirtual

Reimplemented from edm::one::EDProducerBase.

Definition at line 64 of file EDMtoMEConverter.h.

64 {};
void EDMtoMEConverter::endLuminosityBlock ( const edm::LuminosityBlock ,
const edm::EventSetup  
)
inlinefinal

Definition at line 68 of file EDMtoMEConverter.h.

68 {};
void EDMtoMEConverter::endLuminosityBlockProduce ( edm::LuminosityBlock iLumi,
edm::EventSetup const &  iSetup 
)
override

Definition at line 304 of file EDMtoMEConverter.cc.

References b, convertOnEndLumi, dqmLumiToken_, g, getData(), dqm::dqmstoreimpl::DQMStore::meBookerGetter(), Utilities::operator, and edm::LuminosityBlock::put().

Referenced by produce().

304  {
305  if (convertOnEndLumi) {
307  store->meBookerGetter([&](DQMStore::IBooker &b, DQMStore::IGetter &g) { getData(b, g, iLumi); });
308  }
309 
310  iLumi.put(dqmLumiToken_, std::make_unique<DQMToken>());
311 }
dqm::legacy::DQMStore DQMStore
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e g
Definition: Activities.doc:4
void put(std::unique_ptr< PROD > product)
Put a new product.
edm::EDPutTokenT< DQMToken > dqmLumiToken_
double b
Definition: hdecay.h:118
void getData(DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, T &iGetFrom)
void EDMtoMEConverter::endRun ( const edm::Run ,
const edm::EventSetup  
)
inlinefinal

Definition at line 66 of file EDMtoMEConverter.h.

66 {};
void EDMtoMEConverter::endRunProduce ( edm::Run run,
edm::EventSetup const &  setup 
)
override

Definition at line 295 of file EDMtoMEConverter.cc.

References b, convertOnEndRun, dqmRunToken_, g, getData(), dqm::dqmstoreimpl::DQMStore::meBookerGetter(), Utilities::operator, and edm::Run::put().

Referenced by produce().

295  {
296  if (convertOnEndRun) {
298  store->meBookerGetter([&](DQMStore::IBooker &b, DQMStore::IGetter &g) { getData(b, g, iRun); });
299  }
300 
301  iRun.put(dqmRunToken_, std::make_unique<DQMToken>());
302 }
dqm::legacy::DQMStore DQMStore
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e g
Definition: Activities.doc:4
edm::EDPutTokenT< DQMToken > dqmRunToken_
double b
Definition: hdecay.h:118
void getData(DQMStore::IBooker &iBooker, DQMStore::IGetter &iGetter, T &iGetFrom)
template<class T >
void EDMtoMEConverter::getData ( DQMStore::IBooker iBooker,
DQMStore::IGetter iGetter,
T iGetFrom 
)

Definition at line 314 of file EDMtoMEConverter.cc.

References constexpr, gather_cfg::cout, DeadROC_duringRun::dir, mps_fire::i, edm::HandleBase::isValid(), dqmiolumiharvest::j, hlt_dqm_clientPB-live_cfg::me, name, BTVHLTOfflineSource_cfi::pathname, cms::dd::split(), AlCaHLTBitMon_QueryRunRegistry::string, tokens_, and verbosity.

Referenced by endLuminosityBlockProduce(), endRunProduce(), and produce().

314  {
315  constexpr char MsgLoggerCat[] = "EDMtoMEConverter_getData";
316 
317  if (verbosity >= 0)
318  edm::LogInfo(MsgLoggerCat) << "\nRestoring MonitorElements.";
319 
320  for_each(tokens_, [&](const auto &tok) {
321  using Tokens_T = typename std::decay<decltype(tok)>::type;
322  using METype = typename Tokens_T::type;
323  using MEtoEDM_T = typename Tokens_T::Product;
324  edm::Handle<MEtoEDM_T> metoedm;
325  tok.getData(iGetFrom, metoedm);
326  if (!metoedm.isValid()) {
327  //edm::LogWarning(MsgLoggerCat)
328  // << "MEtoEDM<TH1F> doesn't exist in run";
329  return;
330  }
331 
332  std::vector<typename MEtoEDM_T::MEtoEDMObject> metoedmobject = metoedm->getMEtoEdmObject();
333 
334  for (unsigned int i = 0; i < metoedmobject.size(); ++i) {
335  // get full path of monitor element
336  const std::string &pathname = metoedmobject[i].name;
337  if (verbosity > 0)
338  std::cout << pathname << std::endl;
339 
341 
342  // deconstruct path from fullpath
343  StringList fulldir = StringOps::split(pathname, "/");
344  std::string name = *(fulldir.end() - 1);
345 
346  for (unsigned j = 0; j < fulldir.size() - 1; ++j) {
347  dir += fulldir[j];
348  if (j != fulldir.size() - 2)
349  dir += "/";
350  }
351 
352  // define new monitor element
353  MonitorElement *me =
354  AddMonitorElement<METype>::call(iBooker, iGetter, &metoedmobject[i].object, dir, name, iGetFrom);
355  maybeSetLumiFlag(me, iGetFrom);
356 
357  } // end loop thorugh metoedmobject
358  });
359 }
std::vector< std::string_view > split(std::string_view, const char *)
type
Definition: HCALResponse.h:21
std::tuple< Tokens< TH1F >, Tokens< TH1S >, Tokens< TH1D >, Tokens< TH2F >, Tokens< TH2S >, Tokens< TH2D >, Tokens< TH3F >, Tokens< TProfile >, Tokens< TProfile2D >, Tokens< double >, Tokens< int >, Tokens< long long >, Tokens< TString > > tokens_
bool isValid() const
Definition: HandleBase.h:70
#define constexpr
void EDMtoMEConverter::produce ( edm::Event ,
edm::EventSetup const &   
)
inlinefinalvirtual

Member Data Documentation

bool EDMtoMEConverter::convertOnEndLumi
private

Definition at line 84 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter(), and endLuminosityBlockProduce().

bool EDMtoMEConverter::convertOnEndRun
private

Definition at line 85 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter(), and endRunProduce().

edm::EDPutTokenT<DQMToken> EDMtoMEConverter::dqmLumiToken_
private

Definition at line 120 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter(), and endLuminosityBlockProduce().

edm::EDPutTokenT<DQMToken> EDMtoMEConverter::dqmRunToken_
private

Definition at line 121 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter(), and endRunProduce().

int EDMtoMEConverter::frequency
private

Definition at line 82 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter().

std::string EDMtoMEConverter::name
private

Definition at line 80 of file EDMtoMEConverter.h.

Referenced by ElectronMVAID.ElectronMVAID::__call__(), FWLite.ElectronMVAID::__call__(), dirstructure.Directory::__create_pie_image(), DisplayManager.DisplayManager::__del__(), dqm_interfaces.DirID::__eq__(), dirstructure.Directory::__get_full_path(), dirstructure.Comparison::__get_img_name(), dataset.Dataset::__getDataType(), dataset.Dataset::__getFileInfoList(), dirstructure.Comparison::__make_image(), core.autovars.NTupleVariable::__repr__(), core.autovars.NTupleObjectType::__repr__(), core.autovars.NTupleObject::__repr__(), core.autovars.NTupleCollection::__repr__(), dirstructure.Directory::__repr__(), dqm_interfaces.DirID::__repr__(), dirstructure.Comparison::__repr__(), config.Service::__setattr__(), config.CFG::__str__(), counter.Counter::__str__(), average.Average::__str__(), FWLite.WorkingPoints::_reformat_cut_definitions(), core.autovars.NTupleObjectType::addSubObjects(), core.autovars.NTupleObjectType::addVariables(), core.autovars.NTupleObjectType::allVars(), dirstructure.Directory::calcStats(), validation.Sample::digest(), python.rootplot.utilities.Hist::divide(), python.rootplot.utilities.Hist::divide_wilson(), DisplayManager.DisplayManager::Draw(), TreeCrawler.Package::dump(), EDMtoMEConverter(), core.autovars.NTupleVariable::fillBranch(), core.autovars.NTupleObject::fillBranches(), core.autovars.NTupleCollection::fillBranchesScalar(), core.autovars.NTupleCollection::fillBranchesVector(), core.autovars.NTupleCollection::get_cpp_declaration(), core.autovars.NTupleCollection::get_cpp_wrapper_class(), core.autovars.NTupleCollection::get_py_wrapper_class(), utils.StatisticalTest::get_status(), getData(), production_tasks.Task::getname(), dataset.CMSDataset::getPrimaryDatasetEntries(), dataset.PrivateDataset::getPrimaryDatasetEntries(), VIDSelectorBase.VIDSelectorBase::initialize(), personalPlayback.Applet::log(), core.autovars.NTupleVariable::makeBranch(), core.autovars.NTupleObject::makeBranches(), core.autovars.NTupleCollection::makeBranchesScalar(), core.autovars.NTupleCollection::makeBranchesVector(), dirstructure.Directory::print_report(), dataset.BaseDataset::printInfo(), dataset.Dataset::printInfo(), production_tasks.MonitorJobs::run(), python.rootplot.utilities.Hist::TGraph(), python.rootplot.utilities.Hist::TH1F(), Vispa.Views.PropertyView.Property::valueChanged(), counter.Counter::write(), and average.Average::write().

std::tuple<Tokens<TH1F>, Tokens<TH1S>, Tokens<TH1D>, Tokens<TH2F>, Tokens<TH2S>, Tokens<TH2D>, Tokens<TH3F>, Tokens<TProfile>, Tokens<TProfile2D>, Tokens<double>, Tokens<int>, Tokens<long long>, Tokens<TString> > EDMtoMEConverter::tokens_
private

Definition at line 118 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter(), and getData().

int EDMtoMEConverter::verbosity
private

Definition at line 81 of file EDMtoMEConverter.h.

Referenced by EDMtoMEConverter(), and getData().