CMS 3D CMS Logo

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

#include <HLTConfigProvider.h>

Classes

struct  HLTConfigCounterSentry
 

Public Member Functions

bool changed () const
 changed? More...
 
const std::vector< std::string > & datasetContent (unsigned int dataset) const
 names of trigger paths in dataset with index i More...
 
const std::vector< std::string > & datasetContent (const std::string &dataset) const
 names of trigger paths in dataset with name More...
 
const std::vector< std::vector
< std::string > > & 
datasetContents () const
 names of trigger paths for all datasets More...
 
unsigned int datasetIndex (const std::string &dataset) const
 index of dataset with name More...
 
const std::string & datasetName (unsigned int dataset) const
 name of dataset with index i More...
 
const std::vector< std::string > & datasetNames () const
 
void dump (const std::string &what) const
 Dumping config info to cout. More...
 
const std::string & globalTag () const
 global tag More...
 
 HLTConfigProvider ()
 c'tor More...
 
const std::vector< std::vector
< std::pair< bool, std::string > > > & 
hltL1GTSeeds () const
 
const std::vector< std::pair
< bool, std::string > > & 
hltL1GTSeeds (const std::string &trigger) const
 HLTLevel1GTSeed modules for trigger path with name. More...
 
const std::vector< std::pair
< bool, std::string > > & 
hltL1GTSeeds (unsigned int trigger) const
 HLTLevel1GTSeed modules for trigger path with index i. More...
 
bool init (const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)
 d'tor More...
 
bool inited () const
 Accessors (const methods) More...
 
const std::string moduleEDMType (const std::string &module) const
 C++ base class name of module. More...
 
unsigned int moduleIndex (unsigned int trigger, const std::string &module) const
 slot position of module on trigger path (0 to size-1) More...
 
unsigned int moduleIndex (const std::string &trigger, const std::string &module) const
 
const std::string & moduleLabel (unsigned int trigger, unsigned int module) const
 
const std::string & moduleLabel (const std::string &trigger, unsigned int module) const
 
const std::vector< std::string > & moduleLabels (unsigned int trigger) const
 label(s) of module(s) on a trigger path More...
 
const std::vector< std::string > & moduleLabels (const std::string &trigger) const
 
const edm::ParameterSetmodulePSet (const std::string &module) const
 ParameterSet of module. More...
 
const std::string moduleType (const std::string &module) const
 C++ class name of module. More...
 
const std::vector< std::string > & prescaleLabels () const
 low-level data member access More...
 
int prescaleSet (const edm::Event &iEvent, const edm::EventSetup &iSetup) const
 
unsigned int prescaleSize () const
 
const std::map< std::string,
std::vector< unsigned int > > & 
prescaleTable () const
 
unsigned int prescaleValue (unsigned int set, const std::string &trigger) const
 HLT prescale value in specific prescale set for a specific trigger path. More...
 
unsigned int prescaleValue (const edm::Event &iEvent, const edm::EventSetup &iSetup, const std::string &trigger) const
 combining the two methods above More...
 
std::pair< int, int > prescaleValues (const edm::Event &iEvent, const edm::EventSetup &iSetup, const std::string &trigger) const
 Combined L1T (pair.first) and HLT (pair.second) prescales per HLT path. More...
 
std::pair< std::vector
< std::pair< std::string, int >
>, int > 
prescaleValuesInDetail (const edm::Event &iEvent, const edm::EventSetup &iSetup, const std::string &trigger) const
 
const std::string & processName () const
 process name More...
 
const edm::ParameterSetprocessPSet () const
 ParameterSet of process. More...
 
bool saveTags (const std::string &module) const
 Is module an L3 filter (ie, tracked saveTags=true) More...
 
const std::vector< std::string > & saveTagsModules (unsigned int trigger) const
 
const std::vector< std::string > & saveTagsModules (const std::string &trigger) const
 
unsigned int size () const
 number of trigger paths in trigger table More...
 
unsigned int size (unsigned int trigger) const
 number of modules on a specific trigger path More...
 
unsigned int size (const std::string &trigger) const
 
const std::vector< std::string > & streamContent (unsigned int stream) const
 names of datasets in stream with index i More...
 
const std::vector< std::string > & streamContent (const std::string &stream) const
 names of datasets in stream with name More...
 
const std::vector< std::vector
< std::string > > & 
streamContents () const
 names of datasets for all streams More...
 
unsigned int streamIndex (const std::string &stream) const
 index of stream with name More...
 
const std::string & streamName (unsigned int stream) const
 name of stream with index i More...
 
const std::vector< std::string > & streamNames () const
 
const std::string & tableName () const
 HLT ConfDB table name. More...
 
unsigned int triggerIndex (const std::string &triggerName) const
 slot position of trigger path in trigger table (0 to size-1) More...
 
const std::string & triggerName (unsigned int triggerIndex) const
 
const std::vector< std::string > & triggerNames () const
 names of trigger paths More...
 

Static Public Member Functions

static const std::vector
< std::string > 
matched (const std::vector< std::string > &inputs, const std::string &pattern)
 regexp processing More...
 
static const std::string removeVersion (const std::string &trigger)
 
static const std::vector
< std::string > 
restoreVersion (const std::vector< std::string > &inputs, const std::string &trigger)
 

Private Member Functions

void clear ()
 
void getDataFrom (const edm::ParameterSetID &iID)
 
void init (const edm::ProcessHistory &iHistory, const std::string &processName)
 
void init (const std::string &processName)
 

Private Attributes

bool changed_
 
const HLTConfigDatahltConfigData_
 
bool inited_
 
boost::shared_ptr< L1GtUtilsl1GtUtils_
 
std::string processName_
 data members More...
 
HLTConfigCounterSentry sentry_
 

Detailed Description

This class provides access routines to get hold of the HLT Configuration

Author
Martin Grunewald

See header file for documentation

Author
Martin Grunewald

Definition at line 32 of file HLTConfigProvider.h.

Constructor & Destructor Documentation

HLTConfigProvider::HLTConfigProvider ( )

c'tor

Definition at line 33 of file HLTConfigProvider.cc.

33  :
34  processName_(""),
35  inited_(false),
36  changed_(true),
38  l1GtUtils_(new L1GtUtils())
39 {
40  // HLTConfigDataRegistry::instance()->extra().increment();
41 }
static const HLTConfigData * s_dummyHLTConfigData()
std::string processName_
data members
const HLTConfigData * hltConfigData_
boost::shared_ptr< L1GtUtils > l1GtUtils_

Member Function Documentation

bool HLTConfigProvider::changed ( ) const
inline

changed?

Definition at line 68 of file HLTConfigProvider.h.

References changed_.

Referenced by EmDQM::dqmBeginRun().

68  {
69  return changed_;
70  }
void HLTConfigProvider::clear ( void  )
private

Definition at line 265 of file HLTConfigProvider.cc.

References changed_, hltConfigData_, inited_, l1GtUtils_, processName_, and s_dummyHLTConfigData().

Referenced by getDataFrom(), and init().

266 {
267  // clear all data members
268 
269  processName_ = "";
270  inited_ = false;
271  changed_ = true;
273  *l1GtUtils_ = L1GtUtils();
274 
275  return;
276 }
static const HLTConfigData * s_dummyHLTConfigData()
std::string processName_
data members
const HLTConfigData * hltConfigData_
boost::shared_ptr< L1GtUtils > l1GtUtils_
const std::vector<std::string>& HLTConfigProvider::datasetContent ( unsigned int  dataset) const
inline

names of trigger paths in dataset with index i

Definition at line 225 of file HLTConfigProvider.h.

References HLTConfigData::datasetContent(), and hltConfigData_.

Referenced by HLTOfflineReproducibility::beginRun(), HLTScalers::beginRun(), FourVectorHLTOnline::beginRun(), TrigResRateMon::beginRun(), FourVectorHLTOffline::beginRun(), GeneralHLTOffline::bookHistograms(), and TriggerRatesMonitor::dqmBeginRun().

225  {
227  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & datasetContent(unsigned int dataset) const
names of trigger paths in dataset with index i
tuple dataset
Definition: dataset.py:393
const std::vector<std::string>& HLTConfigProvider::datasetContent ( const std::string &  dataset) const
inline

names of trigger paths in dataset with name

Definition at line 229 of file HLTConfigProvider.h.

References HLTConfigData::datasetContent(), and hltConfigData_.

229  {
231  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & datasetContent(unsigned int dataset) const
names of trigger paths in dataset with index i
tuple dataset
Definition: dataset.py:393
const std::vector<std::vector<std::string> >& HLTConfigProvider::datasetContents ( ) const
inline

names of trigger paths for all datasets

Definition at line 221 of file HLTConfigProvider.h.

References HLTConfigData::datasetContents(), and hltConfigData_.

Referenced by HLTrigReport::reset(), and TriggerJSONMonitoring::resetRun().

221  {
223  }
const HLTConfigData * hltConfigData_
const std::vector< std::vector< std::string > > & datasetContents() const
names of trigger paths for all datasets
unsigned int HLTConfigProvider::datasetIndex ( const std::string &  dataset) const
inline

index of dataset with name

Definition at line 217 of file HLTConfigProvider.h.

References HLTConfigData::datasetIndex(), and hltConfigData_.

217  {
219  }
const HLTConfigData * hltConfigData_
tuple dataset
Definition: dataset.py:393
unsigned int datasetIndex(const std::string &dataset) const
index of dataset with name
const std::string& HLTConfigProvider::datasetName ( unsigned int  dataset) const
inline

name of dataset with index i

Definition at line 213 of file HLTConfigProvider.h.

References HLTConfigData::datasetName(), and hltConfigData_.

213  {
215  }
const std::string & datasetName(unsigned int dataset) const
name of dataset with index i
const HLTConfigData * hltConfigData_
tuple dataset
Definition: dataset.py:393
const std::vector<std::string>& HLTConfigProvider::datasetNames ( ) const
inline

Datasets list of names of all datasets

Definition at line 209 of file HLTConfigProvider.h.

References HLTConfigData::datasetNames(), and hltConfigData_.

Referenced by HLTOfflineReproducibility::beginRun(), FourVectorHLTOnline::beginRun(), FourVectorHLTOffline::beginRun(), TriggerRatesMonitor::bookHistograms(), TriggerRatesMonitor::dqmBeginRun(), HLTrigReport::reset(), and TriggerJSONMonitoring::resetRun().

209  {
210  return hltConfigData_->datasetNames();
211  }
const std::vector< std::string > & datasetNames() const
Datasets.
const HLTConfigData * hltConfigData_
void HLTConfigProvider::dump ( const std::string &  what) const
inline

Dumping config info to cout.

Definition at line 57 of file HLTConfigProvider.h.

References HLTConfigData::dump(), and hltConfigData_.

Referenced by HLTEventAnalyzerAOD::beginRun(), HLTEventAnalyzerRAW::beginRun(), prescaleValues(), and prescaleValuesInDetail().

57  {
58  hltConfigData_->dump(what);
59  }
const HLTConfigData * hltConfigData_
void dump(const std::string &what) const
Dumping config info to cout.
void HLTConfigProvider::getDataFrom ( const edm::ParameterSetID iID)
private

Definition at line 154 of file HLTConfigProvider.cc.

References changed_, clear(), edm::detail::ThreadSafeRegistry< KEY, T, E >::getMapped(), hltConfigData_, edm::ParameterSet::id(), inited_, edm::detail::ThreadSafeRegistry< KEY, T, E >::insertMapped(), edm::pset::Registry::instance(), edm::detail::ThreadSafeRegistry< KEY, T, E >::instance(), edm::Hash< I >::isValid(), processPSet(), and s_dummyHLTConfigData().

Referenced by init().

155 {
156  //is it in our registry?
158  const HLTConfigData* d = reg->getMapped(iID);
159  if(0 != d) {
160  changed_ = true;
161  inited_ = true;
162  hltConfigData_ = d;
163  } else {
164  const edm::ParameterSet* processPSet = 0;
165  if ( 0 != (processPSet = edm::pset::Registry::instance()->getMapped(iID))) {
166  if (not processPSet->id().isValid()) {
167  clear();
168  edm::LogError("HLTConfigProvider") << "ProcessPSet found is empty!";
169  changed_ = true;
170  inited_ = false;
172  return;
173  } else {
174  clear();
175  reg->insertMapped( HLTConfigData(processPSet));
176  changed_ = true;
177  inited_ = true;
178  hltConfigData_ = reg->getMapped(processPSet->id());
179  return;
180  }
181  } else {
182  clear();
183  edm::LogError("HLTConfigProvider") << "ProcessPSet not found in regsistry!";
184  changed_ = true;
185  inited_ = false;
187  return;
188  }
189  }
190  return;
191 }
ParameterSetID id() const
static ThreadSafeRegistry * instance()
bool getMapped(key_type const &k, value_type &result) const
static const HLTConfigData * s_dummyHLTConfigData()
bool insertMapped(value_type const &v)
const HLTConfigData * hltConfigData_
const edm::ParameterSet & processPSet() const
ParameterSet of process.
bool isValid() const
Definition: Hash.h:150
static Registry * instance()
Definition: Registry.cc:14
const std::string& HLTConfigProvider::globalTag ( ) const
inline

global tag

Definition at line 78 of file HLTConfigProvider.h.

References HLTConfigData::globalTag(), and hltConfigData_.

78  {
79  return hltConfigData_->globalTag();
80  }
const HLTConfigData * hltConfigData_
const std::string & globalTag() const
GlobalTag.globaltag.
const std::vector<std::vector<std::pair<bool,std::string> > >& HLTConfigProvider::hltL1GTSeeds ( ) const
inline

HLTLevel1GTSeed module HLTLevel1GTSeed modules for all trigger paths

Definition at line 167 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::hltL1GTSeeds().

Referenced by L1GtTriggerMenuTester::associateL1SeedsHltPath(), prescaleValues(), prescaleValuesInDetail(), PrescaleWeightProvider::prescaleWeight(), and pat::PATTriggerProducer::produce().

167  {
168  return hltConfigData_->hltL1GTSeeds();
169  }
const std::vector< std::vector< std::pair< bool, std::string > > > & hltL1GTSeeds() const
const HLTConfigData * hltConfigData_
const std::vector<std::pair<bool,std::string> >& HLTConfigProvider::hltL1GTSeeds ( const std::string &  trigger) const
inline

HLTLevel1GTSeed modules for trigger path with name.

Definition at line 171 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::hltL1GTSeeds().

171  {
172  return hltConfigData_->hltL1GTSeeds(trigger);
173  }
const std::vector< std::vector< std::pair< bool, std::string > > > & hltL1GTSeeds() const
const HLTConfigData * hltConfigData_
const std::vector<std::pair<bool,std::string> >& HLTConfigProvider::hltL1GTSeeds ( unsigned int  trigger) const
inline

HLTLevel1GTSeed modules for trigger path with index i.

Definition at line 175 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::hltL1GTSeeds().

175  {
176  return hltConfigData_->hltL1GTSeeds(trigger);
177  }
const std::vector< std::vector< std::pair< bool, std::string > > > & hltL1GTSeeds() const
const HLTConfigData * hltConfigData_
bool HLTConfigProvider::init ( const edm::Run iRun,
const edm::EventSetup iSetup,
const std::string &  processName,
bool &  changed 
)

d'tor

Run-dependent initialisation (non-const method) "init" return value indicates whether intitialisation has succeeded "changed" parameter indicates whether the config has actually changed

L1 GTA V3: https://twiki.cern.ch/twiki/bin/view/CMSPublic/SWGuideL1TriggerL1GtUtils#Version_3

Definition at line 65 of file HLTConfigProvider.cc.

References changed_, edm::RunBase::id(), inited_, l1GtUtils_, edm::Run::processHistory(), processName(), processName_, useL1EventSetup(), and useL1GtTriggerMenuLite().

Referenced by L1GtTriggerMenuTester::associateL1SeedsHltPath(), EwkElecDQM::beginRun(), CandidateTriggerObjectProducer::beginRun(), HLTMonBTagIPSource::beginRun(), HLTMonBTagMuSource::beginRun(), HLTEventAnalyzerAOD::beginRun(), HLTEventAnalyzerRAW::beginRun(), EwkMuDQM::beginRun(), StudyHLT::beginRun(), TopElectronHLTOfflineSource::beginRun(), HLTMonBitSummary::beginRun(), EwkMuLumiMonitorDQM::beginRun(), PixelVTXMonitor::beginRun(), IsoTrig::beginRun(), LumiCalculator::beginRun(), HLTJetMETDQMSource::beginRun(), HLTrigReport::beginRun(), HLTInclusiveVBFSource::beginRun(), pat::PATTriggerEventProducer::beginRun(), QcdUeDQM::beginRun(), pat::PATTriggerProducer::beginRun(), BTagHLTOfflineSource::beginRun(), HLTExoticaSubAnalysis::beginRun(), HLTHiggsSubAnalysis::beginRun(), TriggerJSONMonitoring::beginRun(), JetMETHLTOfflineSource::beginRun(), HLTInfo::beginRun(), TriggerValidator::beginRun(), HLTOfflineReproducibility::beginRun(), HLTJetMETValidation::beginRun(), EgHLTOfflineSummaryClient::beginRun(), HLTScalers::beginRun(), EgHLTOfflineClient::beginRun(), FourVectorHLTOnline::beginRun(), QcdLowPtDQM::beginRun(), EgHLTOfflineSource::beginRun(), TrigResRateMon::beginRun(), FourVectorHLTriggerOffline::beginRun(), FourVectorHLTOffline::beginRun(), TrackerDpgAnalysis::beginRun(), GeneralHLTOffline::bookHistograms(), HLTOniaSource::checkHLTConfiguration(), HLTTauDQMOfflineSource::dqmBeginRun(), HLTMuonValidator::dqmBeginRun(), HLTMuonOfflineAnalyzer::dqmBeginRun(), HeavyFlavorValidation::dqmBeginRun(), TriggerRatesMonitor::dqmBeginRun(), EmDQM::dqmBeginRun(), EmDQMReco::dqmBeginRun(), TopSingleLeptonHLTOfflineDQM::dqmBeginRun(), TopDiLeptonHLTOfflineDQM::dqmBeginRun(), MuScleFit::duringLoop(), init(), PrescaleWeightProvider::initRun(), TriggerHelper::initRun(), GenericTriggerEventFlag::initRun(), and DQMProvInfo::makeHLTKeyInfo().

68  {
69 
70  using namespace std;
71  using namespace edm;
72 
73  LogInfo("HLTConfigData") << "Called (R) with processName '"
74  << processName
75  << "' for " << iRun.id() << endl;
76 
78 
80  l1GtUtils_->getL1GtRunCache(iRun,iSetup,useL1EventSetup,useL1GtTriggerMenuLite);
81 
84  return inited_;
85 
86 }
RunID const & id() const
Definition: RunBase.h:41
std::string processName_
data members
bool changed() const
changed?
boost::shared_ptr< L1GtUtils > l1GtUtils_
ProcessHistory const & processHistory() const
Definition: Run.cc:108
static const bool useL1GtTriggerMenuLite(false)
const std::string & processName() const
process name
bool init(const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)
d&#39;tor
static const bool useL1EventSetup(true)
void HLTConfigProvider::init ( const edm::ProcessHistory iHistory,
const std::string &  processName 
)
private

Check uniqueness (uniqueness should [soon] be enforced by Fw)

Definition at line 88 of file HLTConfigProvider.cc.

References edm::ProcessHistory::begin(), changed_, clear(), edm::ProcessHistory::end(), edm::ParameterSet::exists(), edm::ProcessHistory::getConfigurationForProcess(), getDataFrom(), edm::pset::Registry::getMapped(), hltConfigData_, HLTConfigData::id(), init(), inited_, edm::pset::Registry::instance(), n, edm::processConfiguration, processName(), processName_, processPSet(), and s_dummyHLTConfigData().

88  {
89 
90  using namespace std;
91  using namespace edm;
92 
93  const ProcessHistory::const_iterator hb(iHistory.begin());
94  const ProcessHistory::const_iterator he(iHistory.end());
95 
98 
100  if (processName_=="*") {
101  // auto-discovery of process name
102  for (ProcessHistory::const_iterator hi=hb; hi!=he; ++hi) {
103  if (iHistory.getConfigurationForProcess(hi->processName(),processConfiguration)) {
105  if ((processPSet!=0) && (processPSet->exists("hltTriggerSummaryAOD"))) {
106  processName_=hi->processName();
107  }
108  }
109  }
110  LogInfo("HLTConfigData") << "Auto-discovered processName: '"
111  << processName_ << "'"
112  << endl;
113  }
114  if (processName_=="*") {
115  clear();
116  LogError("HLTConfigData") << "Auto-discovery of processName failed!"
117  << endl;
118  return;
119  }
120 
122  unsigned int n(0);
123  for (ProcessHistory::const_iterator hi=hb; hi!=he; ++hi) {
124  if (hi->processName()==processName_) {n++;}
125  }
126  if (n>1) {
127  clear();
128  LogError("HLTConfigProvider") << " ProcessName '"<< processName_
129  << " found " << n
130  << " times in history!" << endl;
131  return;
132  }
133 
136  if ((hltConfigData_ !=s_dummyHLTConfigData()) && (processConfiguration.parameterSetID() == hltConfigData_->id())) {
137  changed_ = false;
138  inited_ = true;
139  return;
140  } else {
141  getDataFrom(processConfiguration.parameterSetID());
142  }
143  } else {
144  LogError("HLTConfigProvider") << "Falling back to processName-only init!";
145  clear();
147  if (!inited_) {
148  LogError("HLTConfigProvider") << "ProcessName not found in history!";
149  }
150  return;
151  }
152 }
collection_type::const_iterator const_iterator
const_iterator begin() const
void getDataFrom(const edm::ParameterSetID &iID)
bool exists(std::string const &parameterName) const
checks if a parameter exists
processConfiguration
Definition: Schedule.cc:369
static const HLTConfigData * s_dummyHLTConfigData()
std::string processName_
data members
const HLTConfigData * hltConfigData_
bool getConfigurationForProcess(std::string const &name, ProcessConfiguration &config) const
const edm::ParameterSet & processPSet() const
ParameterSet of process.
bool getMapped(key_type const &k, value_type &result) const
Definition: Registry.cc:20
const std::string & processName() const
process name
bool init(const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)
d&#39;tor
const_iterator end() const
edm::ParameterSetID id() const
technical: id() function needed for use with ThreadSafeRegistry
static Registry * instance()
Definition: Registry.cc:14
void HLTConfigProvider::init ( const std::string &  processName)
private

Definition at line 193 of file HLTConfigProvider.cc.

References edm::pset::Registry::begin(), clear(), edm::pset::Registry::end(), getDataFrom(), edm::pset::Registry::getMapped(), edm::ParameterSet::getParameter(), hltConfigData_, i, HLTConfigData::id(), instance, s_dummyHLTConfigData(), AlCaHLTBitMon_QueryRunRegistry::string, and tableName().

194 {
195  using namespace std;
196  using namespace edm;
197 
198  // Obtain ParameterSetID for requested process (with name
199  // processName) from pset registry
200  string pNames("");
201  string hNames("");
202  const ParameterSet* pset = 0;
203  ParameterSetID psetID;
204  unsigned int nPSets(0);
205  const edm::pset::Registry * registry_(pset::Registry::instance());
206  const edm::pset::Registry::const_iterator rb(registry_->begin());
207  const edm::pset::Registry::const_iterator re(registry_->end());
208  for (edm::pset::Registry::const_iterator i = rb; i != re; ++i) {
209  if (i->second.exists("@process_name")) {
210  const std::string pName(i->second.getParameter<string>("@process_name"));
211  pNames += pName+" ";
212  if ( pName == processName ) {
213  psetID = i->first;
214  nPSets++;
215  if ((hltConfigData_ != s_dummyHLTConfigData()) && (hltConfigData_->id()==psetID)) {
216  hNames += tableName();
217  } else if ( 0 != (pset = registry_->getMapped(psetID))) {
218  if (pset->exists("HLTConfigVersion")) {
219  const ParameterSet& HLTPSet(pset->getParameterSet("HLTConfigVersion"));
220  if (HLTPSet.exists("tableName")) {
221  hNames += HLTPSet.getParameter<string>("tableName")+" ";
222  }
223  }
224  }
225  }
226  }
227  }
228 
229  LogVerbatim("HLTConfigProvider") << "Unordered list of all process names found: "
230  << pNames << "." << endl;
231 
232  LogVerbatim("HLTConfigProvider") << "HLT TableName of each selected process: "
233  << hNames << "." << endl;
234 
235  if (nPSets==0) {
236  clear();
237  LogError("HLTConfigProvider") << " Process name '"
238  << processName
239  << "' not found in registry!" << endl;
240  return;
241  }
242  if (psetID==ParameterSetID()) {
243  clear();
244  LogError("HLTConfigProvider") << " Process name '"
245  << processName
246  << "' found but ParameterSetID invalid!"
247  << endl;
248  return;
249  }
250  if (nPSets>1) {
251  clear();
252  LogError("HLTConfigProvider") << " Process name '"
253  << processName
254  << " found " << nPSets
255  << " times in registry!" << endl;
256  return;
257  }
258 
259  getDataFrom(psetID);
260 
261  return;
262 
263 }
T getParameter(std::string const &) const
int i
Definition: DBlmapReader.cc:9
map_type::const_iterator const_iterator
Definition: Registry.h:63
static PFTauRenderPlugin instance
void getDataFrom(const edm::ParameterSetID &iID)
static const HLTConfigData * s_dummyHLTConfigData()
const std::string & tableName() const
HLT ConfDB table name.
const HLTConfigData * hltConfigData_
Hash< ParameterSetType > ParameterSetID
const std::string & processName() const
process name
edm::ParameterSetID id() const
technical: id() function needed for use with ThreadSafeRegistry
bool HLTConfigProvider::inited ( ) const
inline

Accessors (const methods)

initialised?

Definition at line 64 of file HLTConfigProvider.h.

References inited_.

Referenced by TriggerRatesMonitor::analyze(), TriggerRatesMonitor::bookHistograms(), and EmDQM::dqmBeginRun().

64  {
65  return inited_;
66  }
const std::vector< std::string > HLTConfigProvider::matched ( const std::vector< std::string > &  inputs,
const std::string &  pattern 
)
static

regexp processing

Definition at line 422 of file HLTConfigProvider.cc.

References edm::glob2reg(), i, input, n, and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by GenericTriggerEventFlag::expandLogicalExpression(), and restoreVersion().

422  {
423  std::vector<std::string> matched;
424  const boost::regex regexp(edm::glob2reg(pattern));
425  const unsigned int n(inputs.size());
426  for (unsigned int i=0; i<n; ++i) {
427  const std::string& input(inputs[i]);
428  if (boost::regex_match(input,regexp)) matched.push_back(input);
429  }
430  return matched;
431 }
int i
Definition: DBlmapReader.cc:9
static const std::vector< std::string > matched(const std::vector< std::string > &inputs, const std::string &pattern)
regexp processing
std::string glob2reg(std::string const &pattern)
Definition: RegexMatch.cc:22
static std::string const input
Definition: EdmProvDump.cc:44
const std::string HLTConfigProvider::moduleEDMType ( const std::string &  module) const
inline

C++ base class name of module.

Definition at line 146 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleEDMType().

Referenced by FourVectorHLTOnline::beginRun(), FourVectorHLTOffline::beginRun(), GeneralHLTOffline::fillHltMatrix(), EmDQM::getFilterModules(), pat::PATTriggerProducer::ModuleLabelToPathAndFlags::init(), and GeneralHLTOffline::setupHltMatrix().

146  {
148  }
const HLTConfigData * hltConfigData_
const std::string moduleEDMType(const std::string &module) const
C++ base class name of module.
Definition: vlib.h:208
unsigned int HLTConfigProvider::moduleIndex ( unsigned int  trigger,
const std::string &  module 
) const
inline

slot position of module on trigger path (0 to size-1)

Definition at line 133 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleIndex().

Referenced by HLTOfflineReproducibility::analyze(), EmDQM::analyze(), HLTMonBTagMuSource::beginRun(), HLTMonBTagIPSource::beginRun(), HLTMonBitSummary::beginRun(), FourVectorHLTOnline::beginRun(), FourVectorHLTOffline::beginRun(), FourVectorHLTOnline::hasL1Passed(), and pat::PATTriggerProducer::produce().

133  {
134  return hltConfigData_->moduleIndex(trigger,module);
135  }
const HLTConfigData * hltConfigData_
unsigned int moduleIndex(unsigned int trigger, const std::string &module) const
slot position of module on trigger path (0 - size-1)
Definition: vlib.h:208
unsigned int HLTConfigProvider::moduleIndex ( const std::string &  trigger,
const std::string &  module 
) const
inline

Definition at line 136 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleIndex().

136  {
137  return hltConfigData_->moduleIndex(trigger,module);
138  }
const HLTConfigData * hltConfigData_
unsigned int moduleIndex(unsigned int trigger, const std::string &module) const
slot position of module on trigger path (0 - size-1)
Definition: vlib.h:208
const std::string& HLTConfigProvider::moduleLabel ( unsigned int  trigger,
unsigned int  module 
) const
inline

Definition at line 125 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleLabel().

Referenced by HLTOfflineReproducibility::beginRun(), TriggerRatesMonitor::bookHistograms(), EmDQM::getFilterModules(), and pat::PATTriggerProducer::produce().

125  {
126  return hltConfigData_->moduleLabel(trigger,module);
127  }
const HLTConfigData * hltConfigData_
const std::string & moduleLabel(unsigned int trigger, unsigned int module) const
Definition: vlib.h:208
const std::string& HLTConfigProvider::moduleLabel ( const std::string &  trigger,
unsigned int  module 
) const
inline

Definition at line 128 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleLabel().

128  {
129  return hltConfigData_->moduleLabel(trigger,module);
130  }
const HLTConfigData * hltConfigData_
const std::string & moduleLabel(unsigned int trigger, unsigned int module) const
Definition: vlib.h:208
const std::vector<std::string>& HLTConfigProvider::moduleLabels ( unsigned int  trigger) const
inline

label(s) of module(s) on a trigger path

Definition at line 113 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleLabels().

Referenced by EwkMuLumiMonitorDQM::analyze(), IsoTrig::analyze(), HLTJetMETDQMSource::analyze(), FourVectorHLTOnline::analyze(), FourVectorHLTriggerOffline::analyze(), FourVectorHLTOffline::analyze(), HLTEventAnalyzerAOD::analyzeTrigger(), HLTEventAnalyzerRAW::analyzeTrigger(), HLTMonBitSummary::beginRun(), LumiCalculator::beginRun(), HLTJetMETDQMSource::beginRun(), HLTInclusiveVBFSource::beginRun(), BTagHLTOfflineSource::beginRun(), JetMETHLTOfflineSource::beginRun(), HLTOfflineReproducibility::beginRun(), FourVectorHLTOnline::beginRun(), FourVectorHLTriggerOffline::beginRun(), FourVectorHLTOffline::beginRun(), HLTOniaSource::checkHLTConfiguration(), HeavyFlavorValidation::dqmBeginRun(), HLTOfflineDQMTopSingleLepton::MonitorSingleLepton::fill(), HLTOfflineDQMTopDiLepton::MonitorDiLepton::fill(), GeneralHLTOffline::fillHltMatrix(), JetMETHLTOfflineSource::getL1ConditionModuleName(), FourVectorHLTOnline::getL1ConditionModuleName(), TrigResRateMon::getL1ConditionModuleName(), FourVectorHLTOffline::getL1ConditionModuleName(), egHLT::trigTools::getL1SeedFilterOfPath(), pat::PATTriggerProducer::ModuleLabelToPathAndFlags::init(), HLTMuonValidator::moduleLabels(), HLTMuonOfflineAnalyzer::moduleLabels(), HLTrigReport::reset(), TriggerJSONMonitoring::resetRun(), GeneralHLTOffline::setupHltMatrix(), and egHLT::trigTools::translateFiltersToPathNames().

113  {
114  return hltConfigData_->moduleLabels(trigger);
115  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & moduleLabels(unsigned int trigger) const
label(s) of module(s) on a trigger path
const std::vector<std::string>& HLTConfigProvider::moduleLabels ( const std::string &  trigger) const
inline

Definition at line 116 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleLabels().

116  {
117  return hltConfigData_->moduleLabels(trigger);
118  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & moduleLabels(unsigned int trigger) const
label(s) of module(s) on a trigger path
const edm::ParameterSet& HLTConfigProvider::modulePSet ( const std::string &  module) const
inline
const std::string HLTConfigProvider::moduleType ( const std::string &  module) const
inline

C++ class name of module.

Definition at line 141 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::moduleType().

Referenced by HLTOfflineReproducibility::analyze(), HLTEventAnalyzerAOD::analyzeTrigger(), HLTEventAnalyzerRAW::analyzeTrigger(), HLTMonBitSummary::beginRun(), LumiCalculator::beginRun(), HLTJetMETDQMSource::beginRun(), HLTInclusiveVBFSource::beginRun(), BTagHLTOfflineSource::beginRun(), JetMETHLTOfflineSource::beginRun(), HLTOfflineReproducibility::beginRun(), FourVectorHLTOnline::beginRun(), FourVectorHLTriggerOffline::beginRun(), FourVectorHLTOffline::beginRun(), TriggerRatesMonitor::bookHistograms(), HLTOfflineDQMTopSingleLepton::MonitorSingleLepton::fill(), HLTOfflineDQMTopDiLepton::MonitorDiLepton::fill(), GeneralHLTOffline::fillHltMatrix(), EmDQM::getFilterModules(), JetMETHLTOfflineSource::getL1ConditionModuleName(), FourVectorHLTOnline::getL1ConditionModuleName(), TrigResRateMon::getL1ConditionModuleName(), FourVectorHLTOffline::getL1ConditionModuleName(), HLTTauDQMPath::HLTTauDQMPath(), pat::PATTriggerProducer::ModuleLabelToPathAndFlags::init(), EmDQM::makePSetForEgammaGenericFilter(), EmDQM::makePSetForEgammaGenericQuadraticFilter(), EmDQM::makePSetForElectronGenericFilter(), CandidateTriggerObjectProducer::produce(), pat::PATTriggerProducer::produce(), HLTrigReport::reset(), TriggerJSONMonitoring::resetRun(), and GeneralHLTOffline::setupHltMatrix().

141  {
143  }
const HLTConfigData * hltConfigData_
const std::string moduleType(const std::string &module) const
C++ class name of module.
Definition: vlib.h:208
const std::vector<std::string>& HLTConfigProvider::prescaleLabels ( ) const
inline

low-level data member access

Definition at line 260 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::prescaleLabels().

Referenced by pat::PATTriggerProducer::produce().

260  {
261  return hltConfigData_->prescaleLabels();
262  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & prescaleLabels() const
low-level data member access
int HLTConfigProvider::prescaleSet ( const edm::Event iEvent,
const edm::EventSetup iSetup 
) const

HLT prescale values via (L1) EventSetup current (default) prescale set index - to be taken from L1GtUtil via Event

error - notify user!

Definition at line 279 of file HLTConfigProvider.cc.

References L1GtUtils::AlgorithmTrigger, l1GtUtils_, L1GtUtils::TechnicalTrigger, useL1EventSetup(), and useL1GtTriggerMenuLite().

Referenced by EwkElecDQM::analyze(), EwkMuDQM::analyze(), prescaleValue(), prescaleValues(), prescaleValuesInDetail(), and pat::PATTriggerProducer::produce().

279  {
280  // return hltPrescaleTable_.set();
281  l1GtUtils_->getL1GtRunCache(iEvent,iSetup,useL1EventSetup,useL1GtTriggerMenuLite);
282  int errorTech(0);
283  const int psfsiTech(l1GtUtils_->prescaleFactorSetIndex(iEvent,L1GtUtils::TechnicalTrigger,errorTech));
284  int errorPhys(0);
285  const int psfsiPhys(l1GtUtils_->prescaleFactorSetIndex(iEvent,L1GtUtils::AlgorithmTrigger,errorPhys));
286  assert(psfsiTech==psfsiPhys);
287  if ( (errorTech==0) && (errorPhys==0) &&
288  (psfsiTech>=0) && (psfsiPhys>=0) && (psfsiTech==psfsiPhys) ) {
289  return psfsiPhys;
290  } else {
292  edm::LogError("HLTConfigData")
293  << " Error in determining HLT prescale set index from L1 data using L1GtUtils: "
294  << " Tech/Phys error = " << errorTech << "/" << errorPhys
295  << " Tech/Phys psfsi = " << psfsiTech << "/" << psfsiPhys;
296  return -1;
297  }
298 }
boost::shared_ptr< L1GtUtils > l1GtUtils_
static const bool useL1GtTriggerMenuLite(false)
static const bool useL1EventSetup(true)
unsigned int HLTConfigProvider::prescaleSize ( ) const
inline

HLT prescale info Number of HLT prescale sets

Definition at line 236 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::prescaleSize().

Referenced by EwkMuDQM::analyze(), EwkMuLumiMonitorDQM::analyze(), and pat::PATTriggerProducer::produce().

236  {
237  return hltConfigData_->prescaleSize();
238  }
const HLTConfigData * hltConfigData_
unsigned int prescaleSize() const
const std::map<std::string,std::vector<unsigned int> >& HLTConfigProvider::prescaleTable ( ) const
inline

Definition at line 263 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::prescaleTable().

Referenced by pat::PATTriggerProducer::produce().

263  {
264  return hltConfigData_->prescaleTable();
265  }
const HLTConfigData * hltConfigData_
const std::map< std::string, std::vector< unsigned int > > & prescaleTable() const
unsigned int HLTConfigProvider::prescaleValue ( unsigned int  set,
const std::string &  trigger 
) const
inline

HLT prescale value in specific prescale set for a specific trigger path.

Definition at line 240 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::prescaleValue().

Referenced by EwkElecDQM::analyze(), EwkMuDQM::analyze(), EwkMuLumiMonitorDQM::analyze(), HLTInfo::analyze(), prescaleValue(), prescaleValues(), prescaleValuesInDetail(), PrescaleWeightProvider::prescaleWeight(), and pat::PATTriggerProducer::produce().

240  {
241  return hltConfigData_->prescaleValue(set,trigger);
242  }
unsigned int prescaleValue(unsigned int set, const std::string &trigger) const
HLT prescale value in specific prescale set for a specific trigger path.
const HLTConfigData * hltConfigData_
unsigned int HLTConfigProvider::prescaleValue ( const edm::Event iEvent,
const edm::EventSetup iSetup,
const std::string &  trigger 
) const

combining the two methods above

Definition at line 300 of file HLTConfigProvider.cc.

References prescaleSet(), and prescaleValue().

300  {
301  const int set(prescaleSet(iEvent,iSetup));
302  if (set<0) {
303  return 1;
304  } else {
305  return prescaleValue(static_cast<unsigned int>(set),trigger);
306  }
307 }
unsigned int prescaleValue(unsigned int set, const std::string &trigger) const
HLT prescale value in specific prescale set for a specific trigger path.
int prescaleSet(const edm::Event &iEvent, const edm::EventSetup &iSetup) const
std::pair< int, int > HLTConfigProvider::prescaleValues ( const edm::Event iEvent,
const edm::EventSetup iSetup,
const std::string &  trigger 
) const

Combined L1T (pair.first) and HLT (pair.second) prescales per HLT path.

error - can't handle properly multiple L1GTSeed modules

Definition at line 309 of file HLTConfigProvider.cc.

References asciidump::at, dump(), hltL1GTSeeds(), i, l1GtUtils_, prescaleSet(), prescaleValue(), query::result, edm::second(), size(), AlCaHLTBitMon_QueryRunRegistry::string, useL1EventSetup(), and useL1GtTriggerMenuLite().

Referenced by IsoTrig::analyze(), HLTEventAnalyzerAOD::analyzeTrigger(), TrigResRateMon::fillCountsPerPath(), TrigResRateMon::fillHltMatrix(), and CandidateTriggerObjectProducer::produce().

309  {
310 
311  // start with setting both L1T and HLT prescale values to 0
312  std::pair<int,int> result(std::pair<int,int>(0,0));
313 
314  // get HLT prescale (possible if HLT prescale set index is correctly found)
315  const int set(prescaleSet(iEvent,iSetup));
316  if (set<0) {
317  result.second = -1;
318  } else {
319  result.second = static_cast<int>(prescaleValue(static_cast<unsigned int>(set),trigger));
320  }
321 
322  // get L1T prescale - works only for those hlt trigger paths with
323  // exactly one L1GT seed module which has exactly one L1T name as seed
324  const unsigned int nL1GTSeedModules(hltL1GTSeeds(trigger).size());
325  if (nL1GTSeedModules==0) {
326  // no L1 seed module on path hence no L1 seed hence formally no L1 prescale
327  result.first=1;
328  } else if (nL1GTSeedModules==1) {
329  l1GtUtils_->getL1GtRunCache(iEvent,iSetup,useL1EventSetup,useL1GtTriggerMenuLite);
330  const std::string l1tname(hltL1GTSeeds(trigger).at(0).second);
331  int l1error(0);
332  result.first = l1GtUtils_->prescaleFactor(iEvent,l1tname,l1error);
333  if (l1error!=0) {
334  edm::LogError("HLTConfigData")
335  << " Error in determining L1T prescale for HLT path: '" << trigger
336  << "' with L1T seed: '" << l1tname
337  << "' using L1GtUtils: error code = " << l1error << "." << std::endl
338  << " Note: for this method ('prescaleValues'), only a single L1T name (and not a bit number) is allowed as seed!" << std::endl
339  << " For seeds being complex logical expressions, try the new method 'prescaleValuesInDetail'."<< std::endl;
340  result.first = -1;
341  }
342  } else {
344  std::string dump("'"+hltL1GTSeeds(trigger).at(0).second+"'");
345  for (unsigned int i=1; i!=nL1GTSeedModules; ++i) {
346  dump += " * '"+hltL1GTSeeds(trigger).at(i).second+"'";
347  }
348  edm::LogError("HLTConfigData")
349  << " Error in determining L1T prescale for HLT path: '" << trigger
350  << "' has multiple L1GTSeed modules, " << nL1GTSeedModules
351  << ", with L1 seeds: " << dump
352  << ". (Note: at most one L1GTSeed module is allowed for a proper determination of the L1T prescale!)";
353  result.first = -1;
354  }
355 
356  return result;
357 }
unsigned int size() const
number of trigger paths in trigger table
void dump(const std::string &what) const
Dumping config info to cout.
int i
Definition: DBlmapReader.cc:9
const std::vector< std::vector< std::pair< bool, std::string > > > & hltL1GTSeeds() const
U second(std::pair< T, U > const &p)
boost::shared_ptr< L1GtUtils > l1GtUtils_
unsigned int prescaleValue(unsigned int set, const std::string &trigger) const
HLT prescale value in specific prescale set for a specific trigger path.
tuple result
Definition: query.py:137
static const bool useL1GtTriggerMenuLite(false)
int prescaleSet(const edm::Event &iEvent, const edm::EventSetup &iSetup) const
static const bool useL1EventSetup(true)
list at
Definition: asciidump.py:428
std::pair< std::vector< std::pair< std::string, int > >, int > HLTConfigProvider::prescaleValuesInDetail ( const edm::Event iEvent,
const edm::EventSetup iSetup,
const std::string &  trigger 
) const

error - can't handle properly multiple L1GTSeed modules

Definition at line 359 of file HLTConfigProvider.cc.

References funct::abs(), asciidump::at, dump(), L1GtUtils::LogicalExpressionL1Results::errorCodes(), edm::Event::getRun(), hltL1GTSeeds(), i, L1GtUtils::LogicalExpressionL1Results::isValid(), l1GtUtils_, L1GtUtils::LogicalExpressionL1Results::logicalExpressionRunUpdate(), python.rootplot.argparse::message, L1GtUtils::LogicalExpressionL1Results::prescaleFactors(), prescaleSet(), prescaleValue(), query::result, edm::second(), size(), AlCaHLTBitMon_QueryRunRegistry::string, useL1EventSetup(), and useL1GtTriggerMenuLite().

Referenced by HLTEventAnalyzerAOD::analyzeTrigger().

359  {
360 
361  std::pair<std::vector<std::pair<std::string,int> >,int> result;
362  result.first.clear();
363 
364  // get HLT prescale (possible if HLT prescale set index is correctly found)
365  const int set(prescaleSet(iEvent,iSetup));
366  if (set<0) {
367  result.second = -1;
368  } else {
369  result.second = static_cast<int>(prescaleValue(static_cast<unsigned int>(set),trigger));
370  }
371 
372  // get L1T prescale - works only for those hlt trigger paths with
373  // exactly one L1GT seed module which has exactly one L1T name as seed
374  const unsigned int nL1GTSeedModules(hltL1GTSeeds(trigger).size());
375  if (nL1GTSeedModules==0) {
376  // no L1 seed module on path hence no L1 seed hence formally no L1 prescale
377  result.first.clear();
378  } else if (nL1GTSeedModules==1) {
379  l1GtUtils_->getL1GtRunCache(iEvent,iSetup,useL1EventSetup,useL1GtTriggerMenuLite);
380  const std::string l1tname(hltL1GTSeeds(trigger).at(0).second);
382  l1Logical.logicalExpressionRunUpdate(iEvent.getRun(),iSetup,l1tname);
383  const std::vector<std::pair<std::string, int> >& errorCodes(l1Logical.errorCodes(iEvent));
384  result.first = l1Logical.prescaleFactors();
385  int l1error(l1Logical.isValid() ? 0 : 1);
386  for (unsigned int i=0; i<errorCodes.size(); ++i) {
387  l1error += std::abs(errorCodes[i].second);
388  }
389  if (l1error!=0) {
390  std::ostringstream message;
391  message
392  << " Error in determining L1T prescales for HLT path: '" << trigger
393  << "' with complex L1T seed: '" << l1tname
394  << "' using L1GtUtils: " << std::endl
395  << " isValid=" << l1Logical.isValid()
396  << " l1tname/error/prescale " << errorCodes.size()
397  << std::endl;
398  for (unsigned int i=0; i< errorCodes.size(); ++i) {
399  message << " " << i << ":" << errorCodes[i].first << "/" << errorCodes[i].second << "/" << result.first[i].second;
400  }
401  message << ".";
402  edm::LogError("HLTConfigData") << message.str();
403  result.first.clear();
404  }
405  } else {
407  std::string dump("'"+hltL1GTSeeds(trigger).at(0).second+"'");
408  for (unsigned int i=1; i!=nL1GTSeedModules; ++i) {
409  dump += " * '"+hltL1GTSeeds(trigger).at(i).second+"'";
410  }
411  edm::LogError("HLTConfigData")
412  << " Error in determining L1T prescale for HLT path: '" << trigger
413  << "' has multiple L1GTSeed modules, " << nL1GTSeedModules
414  << ", with L1 seeds: " << dump
415  << ". (Note: at most one L1GTSeed module is allowed for a proper determination of the L1T prescale!)";
416  result.first.clear();
417  }
418 
419  return result;
420 }
unsigned int size() const
number of trigger paths in trigger table
void dump(const std::string &what) const
Dumping config info to cout.
int i
Definition: DBlmapReader.cc:9
const std::vector< std::vector< std::pair< bool, std::string > > > & hltL1GTSeeds() const
Run const & getRun() const
Definition: Event.cc:61
U second(std::pair< T, U > const &p)
boost::shared_ptr< L1GtUtils > l1GtUtils_
unsigned int prescaleValue(unsigned int set, const std::string &trigger) const
HLT prescale value in specific prescale set for a specific trigger path.
tuple result
Definition: query.py:137
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
static const bool useL1GtTriggerMenuLite(false)
int prescaleSet(const edm::Event &iEvent, const edm::EventSetup &iSetup) const
static const bool useL1EventSetup(true)
list at
Definition: asciidump.py:428
const std::string& HLTConfigProvider::processName ( ) const
inline

process name

Definition at line 73 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::processName().

Referenced by GeneralHLTOffline::bookHistograms(), EmDQM::dqmBeginRun(), TopSingleLeptonHLTOfflineDQM::dqmBeginRun(), TopDiLeptonHLTOfflineDQM::dqmBeginRun(), and init().

73  {
74  return hltConfigData_->processName();
75  }
const HLTConfigData * hltConfigData_
const std::string & processName() const
Accessors (const methods)
const edm::ParameterSet& HLTConfigProvider::processPSet ( ) const
inline

ParameterSet of process.

Definition at line 151 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::processPSet().

Referenced by getDataFrom(), and init().

151  {
152  return hltConfigData_->processPSet();
153  }
const HLTConfigData * hltConfigData_
const edm::ParameterSet & processPSet() const
ParameterSet of process.
const std::string HLTConfigProvider::removeVersion ( const std::string &  trigger)
static

Definition at line 433 of file HLTConfigProvider.cc.

Referenced by GeneralHLTOffline::analyze(), JetMETHLTOfflineSource::beginRun(), HLTJetMETValidation::beginRun(), GeneralHLTOffline::bookHistograms(), EmDQM::dqmBeginRun(), GeneralHLTOffline::fillHltMatrix(), and GeneralHLTOffline::setupHltMatrix().

433  {
434  const boost::regex regexp("_v[0-9]+$");
435  return boost::regex_replace(trigger,regexp,"");
436 }
const std::vector< std::string > HLTConfigProvider::restoreVersion ( const std::vector< std::string > &  inputs,
const std::string &  trigger 
)
static

Definition at line 438 of file HLTConfigProvider.cc.

References matched().

Referenced by GenericTriggerEventFlag::expandLogicalExpression().

438  {
439  return matched(inputs,trigger+"_v[0-9]+$");
440 }
static const std::vector< std::string > matched(const std::vector< std::string > &inputs, const std::string &pattern)
regexp processing
bool HLTConfigProvider::saveTags ( const std::string &  module) const
inline

Is module an L3 filter (ie, tracked saveTags=true)

Definition at line 161 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::saveTags().

Referenced by pat::PATTriggerProducer::ModuleLabelToPathAndFlags::init(), EmDQM::makePSetForEgammaGenericFilter(), EmDQM::makePSetForEgammaGenericQuadraticFilter(), and pat::PATTriggerProducer::produce().

161  {
162  return hltConfigData_->saveTags(module);
163  }
bool saveTags(const std::string &module) const
Is module an L3 filter (ie, tracked saveTags=true)
const HLTConfigData * hltConfigData_
Definition: vlib.h:208
const std::vector<std::string>& HLTConfigProvider::saveTagsModules ( unsigned int  trigger) const
inline

Definition at line 119 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::saveTagsModules().

Referenced by egHLT::trigTools::getActiveFilters(), CandidateTriggerObjectProducer::produce(), and pat::PATTriggerProducer::produce().

119  {
120  return hltConfigData_->saveTagsModules(trigger);
121  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & saveTagsModules(unsigned int trigger) const
const std::vector<std::string>& HLTConfigProvider::saveTagsModules ( const std::string &  trigger) const
inline

Definition at line 122 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::saveTagsModules().

122  {
123  return hltConfigData_->saveTagsModules(trigger);
124  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & saveTagsModules(unsigned int trigger) const
unsigned int HLTConfigProvider::size ( void  ) const
inline

number of trigger paths in trigger table

Definition at line 88 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::size().

Referenced by TriggerHelper::acceptHltLogicalExpression(), GenericTriggerEventFlag::acceptHltLogicalExpression(), HLTEventAnalyzerAOD::analyze(), HLTEventAnalyzerRAW::analyze(), IsoTrig::analyze(), TriggerValidator::analyze(), HLTEventAnalyzerAOD::analyzeTrigger(), HLTEventAnalyzerRAW::analyzeTrigger(), L1GtTriggerMenuTester::associateL1SeedsHltPath(), HLTMonBTagIPSource::beginRun(), HLTMonBTagMuSource::beginRun(), HLTEventAnalyzerAOD::beginRun(), HLTEventAnalyzerRAW::beginRun(), LumiCalculator::beginRun(), HLTJetMETDQMSource::beginRun(), HLTInclusiveVBFSource::beginRun(), pat::PATTriggerEventProducer::beginRun(), QcdUeDQM::beginRun(), pat::PATTriggerProducer::beginRun(), BTagHLTOfflineSource::beginRun(), JetMETHLTOfflineSource::beginRun(), HLTOfflineReproducibility::beginRun(), FourVectorHLTOnline::beginRun(), QcdLowPtDQM::beginRun(), FourVectorHLTriggerOffline::beginRun(), FourVectorHLTOffline::beginRun(), TrigResRateMon::bookCountsPerPath(), GeneralHLTOffline::bookHistograms(), TriggerRatesMonitor::bookHistograms(), TriggerRatesMonitor::dqmBeginRun(), EmDQM::dqmBeginRun(), TrigResRateMon::fillCountsPerPath(), JetMETHLTOfflineSource::fillMEforEffWrtMBTrigger(), JetMETHLTOfflineSource::fillMEforEffWrtMuTrigger(), JetMETHLTOfflineSource::fillMEforMonAllTriggerwrtMuonTrigger(), JetMETHLTOfflineSource::fillMEforMonTriggerSummary(), TrigResRateMon::filltestHisto(), EmDQM::findEgammaPaths(), TrigResRateMon::findReferenceTriggerIndex(), egHLT::trigTools::getActiveFilters(), EmDQM::getFilterModules(), PrescaleWeightProvider::initRun(), TriggerHelper::initRun(), GenericTriggerEventFlag::initRun(), DQMProvInfo::makeHLTKeyInfo(), prescaleValues(), prescaleValuesInDetail(), PrescaleWeightProvider::prescaleWeight(), TrigResRateMon::printCountsPerPathThisLumi(), CandidateTriggerObjectProducer::produce(), pat::PATTriggerProducer::produce(), egHLT::trigTools::translateFiltersToPathNames(), HLTInclusiveVBFSource::validPathHLT(), BTagHLTOfflineSource::validPathHLT(), and JetMETHLTOfflineSource::validPathHLT().

88  {
89  return hltConfigData_->size();
90  }
unsigned int size() const
number of trigger paths in trigger table
const HLTConfigData * hltConfigData_
unsigned int HLTConfigProvider::size ( unsigned int  trigger) const
inline

number of modules on a specific trigger path

Definition at line 92 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::size().

92  {
93  return hltConfigData_->size(trigger);
94  }
unsigned int size() const
number of trigger paths in trigger table
const HLTConfigData * hltConfigData_
unsigned int HLTConfigProvider::size ( const std::string &  trigger) const
inline

Definition at line 95 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::size().

95  {
96  return hltConfigData_->size(trigger);
97  }
unsigned int size() const
number of trigger paths in trigger table
const HLTConfigData * hltConfigData_
const std::vector<std::string>& HLTConfigProvider::streamContent ( unsigned int  stream) const
inline

names of datasets in stream with index i

Definition at line 198 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::streamContent().

Referenced by GeneralHLTOffline::analyze(), HLTScalers::beginRun(), TrigResRateMon::beginRun(), GeneralHLTOffline::bookHistograms(), TriggerRatesMonitor::dqmBeginRun(), TrigResRateMon::fillHltMatrix(), and TrigResRateMon::normalizeHLTMatrix().

198  {
200  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & streamContent(unsigned int stream) const
names of datasets in stream with index i
const std::vector<std::string>& HLTConfigProvider::streamContent ( const std::string &  stream) const
inline

names of datasets in stream with name

Definition at line 202 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::streamContent().

202  {
204  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & streamContent(unsigned int stream) const
names of datasets in stream with index i
const std::vector<std::vector<std::string> >& HLTConfigProvider::streamContents ( ) const
inline

names of datasets for all streams

Definition at line 194 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::streamContents().

Referenced by HLTrigReport::reset().

194  {
195  return hltConfigData_->streamContents();
196  }
const HLTConfigData * hltConfigData_
const std::vector< std::vector< std::string > > & streamContents() const
names of datasets for all streams
unsigned int HLTConfigProvider::streamIndex ( const std::string &  stream) const
inline

index of stream with name

Definition at line 190 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::streamIndex().

Referenced by HLTScalers::beginRun().

190  {
192  }
const HLTConfigData * hltConfigData_
unsigned int streamIndex(const std::string &stream) const
index of stream with name
const std::string& HLTConfigProvider::streamName ( unsigned int  stream) const
inline

name of stream with index i

Definition at line 186 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::streamName().

186  {
188  }
const std::string & streamName(unsigned int stream) const
name of stream with index i
const HLTConfigData * hltConfigData_
const std::vector<std::string>& HLTConfigProvider::streamNames ( ) const
inline

Streams list of names of all streams

Definition at line 182 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::streamNames().

Referenced by HLTScalers::beginRun(), GeneralHLTOffline::bookHistograms(), TriggerRatesMonitor::bookHistograms(), TriggerRatesMonitor::dqmBeginRun(), and HLTrigReport::reset().

182  {
183  return hltConfigData_->streamNames();
184  }
const HLTConfigData * hltConfigData_
const std::vector< std::string > & streamNames() const
Streams.
const std::string& HLTConfigProvider::tableName ( ) const
inline

HLT ConfDB table name.

Definition at line 83 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::tableName().

Referenced by L1GtTriggerMenuTester::associateL1SeedsHltPath(), LumiCalculator::beginRun(), GeneralHLTOffline::bookHistograms(), EmDQM::dqmBeginRun(), init(), DQMProvInfo::makeHLTKeyInfo(), and pat::PATTriggerEventProducer::produce().

83  {
84  return hltConfigData_->tableName();
85  }
const HLTConfigData * hltConfigData_
const std::string & tableName() const
HLT ConfDB table name.
unsigned int HLTConfigProvider::triggerIndex ( const std::string &  triggerName) const
inline
const std::string& HLTConfigProvider::triggerName ( unsigned int  triggerIndex) const
inline

Definition at line 103 of file HLTConfigProvider.h.

References hltConfigData_, and HLTConfigData::triggerName().

Referenced by HLTEventAnalyzerAOD::analyze(), HLTEventAnalyzerRAW::analyze(), L1GtTriggerMenuTester::associateL1SeedsHltPath(), LumiCalculator::beginRun(), HLTJetMETDQMSource::beginRun(), HLTInclusiveVBFSource::beginRun(), QcdUeDQM::beginRun(), BTagHLTOfflineSource::beginRun(), JetMETHLTOfflineSource::beginRun(), FourVectorHLTOnline::beginRun(), QcdLowPtDQM::beginRun(), FourVectorHLTriggerOffline::beginRun(), FourVectorHLTOffline::beginRun(), TriggerRatesMonitor::bookHistograms(), TrigResRateMon::fillCountsPerPath(), JetMETHLTOfflineSource::fillMEforEffWrtMBTrigger(), JetMETHLTOfflineSource::fillMEforEffWrtMuTrigger(), JetMETHLTOfflineSource::fillMEforMonAllTriggerwrtMuonTrigger(), JetMETHLTOfflineSource::fillMEforMonTriggerSummary(), TrigResRateMon::filltestHisto(), EmDQM::findEgammaPaths(), TrigResRateMon::findReferenceTriggerIndex(), egHLT::trigTools::getActiveFilters(), TrigResRateMon::printCountsPerPathThisLumi(), egHLT::trigTools::translateFiltersToPathNames(), HLTInclusiveVBFSource::validPathHLT(), BTagHLTOfflineSource::validPathHLT(), and JetMETHLTOfflineSource::validPathHLT().

103  {
105  }
const HLTConfigData * hltConfigData_
unsigned int triggerIndex(const std::string &triggerName) const
slot position of trigger path in trigger table (0 to size-1)
const std::string & triggerName(unsigned int triggerIndex) const
const std::vector<std::string>& HLTConfigProvider::triggerNames ( ) const
inline

Member Data Documentation

bool HLTConfigProvider::changed_
private

Definition at line 282 of file HLTConfigProvider.h.

Referenced by changed(), clear(), getDataFrom(), and init().

const HLTConfigData* HLTConfigProvider::hltConfigData_
private
bool HLTConfigProvider::inited_
private

Definition at line 281 of file HLTConfigProvider.h.

Referenced by clear(), getDataFrom(), init(), and inited().

boost::shared_ptr<L1GtUtils> HLTConfigProvider::l1GtUtils_
private

Definition at line 284 of file HLTConfigProvider.h.

Referenced by clear(), init(), prescaleSet(), prescaleValues(), and prescaleValuesInDetail().

std::string HLTConfigProvider::processName_
private

data members

Definition at line 280 of file HLTConfigProvider.h.

Referenced by clear(), and init().

HLTConfigCounterSentry HLTConfigProvider::sentry_
private

Definition at line 41 of file HLTConfigProvider.h.