CMS 3D CMS Logo

List of all members | Public Member Functions | Protected Attributes
pat::PackedTriggerPrescales Class Reference

#include <PackedTriggerPrescales.h>

Public Member Functions

void addPrescaledTrigger (int index, int prescale)
 
int getPrescaleForIndex (int index) const
 
int getPrescaleForName (const std::string &name, bool prefixOnly=false) const
 
 PackedTriggerPrescales ()
 
 PackedTriggerPrescales (const edm::Handle< edm::TriggerResults > &handle)
 
void setTriggerNames (const edm::TriggerNames &names)
 
const edm::TriggerResultstriggerResults () const
 
 ~PackedTriggerPrescales ()
 

Protected Attributes

std::vector< int > prescaleValues_
 
const edm::TriggerNamestriggerNames_
 
edm::RefCore triggerResults_
 

Detailed Description

Definition at line 10 of file PackedTriggerPrescales.h.

Constructor & Destructor Documentation

◆ PackedTriggerPrescales() [1/2]

pat::PackedTriggerPrescales::PackedTriggerPrescales ( )
inline

Definition at line 12 of file PackedTriggerPrescales.h.

12 : triggerNames_(nullptr) {}
const edm::TriggerNames * triggerNames_

◆ PackedTriggerPrescales() [2/2]

pat::PackedTriggerPrescales::PackedTriggerPrescales ( const edm::Handle< edm::TriggerResults > &  handle)

Definition at line 5 of file PackedTriggerPrescales.cc.

References patZpeak::handle, and prescaleValues_.

◆ ~PackedTriggerPrescales()

pat::PackedTriggerPrescales::~PackedTriggerPrescales ( )
inline

Definition at line 14 of file PackedTriggerPrescales.h.

14 {}

Member Function Documentation

◆ addPrescaledTrigger()

void pat::PackedTriggerPrescales::addPrescaledTrigger ( int  index,
int  prescale 
)

Definition at line 36 of file PackedTriggerPrescales.cc.

References Exception, findQualityFiles::size, and triggerResults.

36  {
37  if (unsigned(index) >= triggerResults().size())
38  throw cms::Exception("InvalidReference", "Index out of bounds");
40 }
size
Write out results.
const edm::TriggerResults & triggerResults() const

◆ getPrescaleForIndex()

int pat::PackedTriggerPrescales::getPrescaleForIndex ( int  index) const

Definition at line 10 of file PackedTriggerPrescales.cc.

References Exception, findQualityFiles::size, and triggerResults.

10  {
11  if (unsigned(index) >= triggerResults().size())
12  throw cms::Exception("InvalidReference", "Index out of bounds");
13  return prescaleValues_[index];
14 }
size
Write out results.
const edm::TriggerResults & triggerResults() const

◆ getPrescaleForName()

int pat::PackedTriggerPrescales::getPrescaleForName ( const std::string &  name,
bool  prefixOnly = false 
) const

Definition at line 16 of file PackedTriggerPrescales.cc.

References Exception, mps_fire::i, dqmiodumpmetadata::n, Skims_PA_cff::name, and names.

16  {
17  if (triggerNames_ == nullptr)
18  throw cms::Exception("LogicError", "getPrescaleForName called without having called setTriggerNames first");
19  if (prefixOnly) {
20  const std::vector<std::string> &names = triggerNames_->triggerNames();
21  size_t siz = name.length() - 1;
22  while (siz > 0 && (name[siz] == '*' || name[siz] == '\0'))
23  siz--;
24  for (unsigned int i = 0, n = names.size(); i < n; ++i) {
25  if (strncmp(name.c_str(), names[i].c_str(), siz) == 0) {
26  return getPrescaleForIndex(i);
27  }
28  }
29  throw cms::Exception("InvalidReference", "Index out of bounds");
30  } else {
32  return getPrescaleForIndex(index);
33  }
34 }
Strings const & triggerNames() const
Definition: TriggerNames.cc:48
const std::string names[nVars_]
unsigned int triggerIndex(std::string_view name) const
Definition: TriggerNames.cc:52
int getPrescaleForIndex(int index) const
const edm::TriggerNames * triggerNames_

◆ setTriggerNames()

void pat::PackedTriggerPrescales::setTriggerNames ( const edm::TriggerNames names)
inline

Definition at line 26 of file PackedTriggerPrescales.h.

References names, and triggerNames_.

26 { triggerNames_ = &names; }
const std::string names[nVars_]
const edm::TriggerNames * triggerNames_

◆ triggerResults()

const edm::TriggerResults& pat::PackedTriggerPrescales::triggerResults ( ) const
inline

Definition at line 22 of file PackedTriggerPrescales.h.

References triggerResults_.

22 { return *edm::getProduct<edm::TriggerResults>(triggerResults_); }

Member Data Documentation

◆ prescaleValues_

std::vector<int> pat::PackedTriggerPrescales::prescaleValues_
protected

Definition at line 32 of file PackedTriggerPrescales.h.

Referenced by PackedTriggerPrescales().

◆ triggerNames_

const edm::TriggerNames* pat::PackedTriggerPrescales::triggerNames_
protected

Definition at line 34 of file PackedTriggerPrescales.h.

Referenced by setTriggerNames().

◆ triggerResults_

edm::RefCore pat::PackedTriggerPrescales::triggerResults_
protected

Definition at line 33 of file PackedTriggerPrescales.h.

Referenced by triggerResults().