CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes | Static Private Attributes
pat::TriggerObjectStandAlone Class Reference

Analysis-level trigger object class (stand-alone) More...

#include "DataFormats/PatCandidates/interface/TriggerObjectStandAlone.h"

Inheritance diagram for pat::TriggerObjectStandAlone:
pat::TriggerObject reco::LeafCandidate reco::Candidate

Public Member Functions

void addAlgorithmName (const std::string &algorithmName, bool algoCondAccepted=true)
 Adds a new L1 algorithm name. More...
 
void addConditionName (const std::string &conditionName)
 Adds a new L1 condition name. More...
 
void addFilterLabel (const std::string &filterLabel)
 Adds a new HLT filter label. More...
 
void addPathName (const std::string &pathName, bool pathLastFilterAccepted=true, bool pathL3FilterAccepted=true)
 Adds a new HLT path name. More...
 
bool algo (const std::string &algorithmName, unsigned algoCondAccepted=1) const
 Calls 'hasAlgorithmName(...)'. More...
 
std::vector< std::string > algorithmNames (bool algoCondAccepted=true) const
 Gets all L1 algorithm names. More...
 
std::vector< std::string > const * allLabels (edm::ParameterSetID const &psetid, const edm::EventBase &event, const edm::TriggerResults &res) const
 
bool coll (const std::string &collName) const override
 Calls 'hasCollection(...)' (method override) More...
 
bool cond (const std::string &conditionName) const
 Calls 'hasConditionName(...)'. More...
 
const std::vector< std::string > & conditionNames () const
 Gets all L1 condition names. More...
 
TriggerObjectStandAlone copy () const
 Methods. More...
 
bool filter (const std::string &filterLabel) const
 Calls 'hasFilterLabel(...)'. More...
 
const std::vector< std::string > & filterLabels () const
 Gets all HLT filter labels. More...
 
bool hasAlgoCondAccepted () const
 
bool hasAlgorithmName (const std::string &algorithmName, bool algoCondAccepted=true) const
 Checks, if a certain L1 algorithm name is assigned. More...
 
bool hasCollection (const std::string &collName) const override
 Checks, if a certain label of original collection is assigned (method overrides) More...
 
bool hasCollection (const edm::InputTag &collName) const override
 
bool hasConditionName (const std::string &conditionName) const
 Checks, if a certain L1 condition name is assigned. More...
 
bool hasFilterLabel (const std::string &filterLabel) const
 Checks, if a certain HLT filter label is assigned. More...
 
bool hasPathL3FilterAccepted () const
 
bool hasPathLastFilterAccepted () const
 Checks, if the usage indicator vector has been filled. More...
 
bool hasPathName (const std::string &pathName, bool pathLastFilterAccepted=false, bool pathL3FilterAccepted=true) const
 Checks, if a certain HLT path name is assigned. More...
 
void packFilterLabels (const edm::EventBase &event, const edm::TriggerResults &res)
 
void packFilterLabels (const std::vector< std::string > &labels)
 pack filter labels into indices; note that the labels must be sorted! More...
 
void packP4 ()
 reduce the precision on the 4-vector More...
 
void packPathNames (const edm::TriggerNames &names)
 pack trigger names into indices More...
 
bool path (const std::string &pathName, unsigned pathLastFilterAccepted=0, unsigned pathL3FilterAccepted=1) const
 Calls 'hasPathName(...)'. More...
 
std::vector< std::string > pathNames (bool pathLastFilterAccepted=false, bool pathL3FilterAccepted=true) const
 Gets all HLT path names. More...
 
const edm::ParameterSetIDpsetID () const
 
void setPSetID (const edm::ParameterSetID &psetId)
 set the psetid of the trigger process More...
 
TriggerObject triggerObject ()
 Gets the pat::TriggerObject (parent class) More...
 
 TriggerObjectStandAlone ()
 Constructors and Destructor. More...
 
 TriggerObjectStandAlone (const TriggerObject &trigObj)
 Constructor from pat::TriggerObject. More...
 
 TriggerObjectStandAlone (const trigger::TriggerObject &trigObj)
 Constructor from trigger::TriggerObject. More...
 
 TriggerObjectStandAlone (const reco::LeafCandidate &leafCand)
 Constructor from reco::Candidate. More...
 
 TriggerObjectStandAlone (const reco::Particle::LorentzVector &vec, int id=0)
 Constructors from Lorentz-vectors and (optional) PDG ID. More...
 
 TriggerObjectStandAlone (const reco::Particle::PolarLorentzVector &vec, int id=0)
 
 TriggerObjectStandAlone (const TriggerObjectStandAlone &)=default
 
void unpackFilterLabels (const std::vector< std::string > &labels)
 unpack filter labels from indices More...
 
void unpackFilterLabels (const edm::EventBase &event, const edm::TriggerResults &res)
 unpack filter labels from indices More...
 
void unpackNamesAndLabels (const edm::EventBase &event, const edm::TriggerResults &res)
 unpack both filter labels and trigger names More...
 
void unpackPathNames (const edm::TriggerNames &names)
 unpack trigger names into indices More...
 
 ~TriggerObjectStandAlone () override
 Destructor. More...
 
- Public Member Functions inherited from pat::TriggerObject
void addFilterId (trigger::TriggerObjectType triggerObjectType)
 
void addFilterId (int triggerObjectType)
 
void addTriggerObjectType (trigger::TriggerObjectType triggerObjectType)
 Add a new trigger object type identifier. More...
 
void addTriggerObjectType (int triggerObjectType)
 
const std::string & collection () const
 Get the label of the collection the trigger object originates from. More...
 
std::vector< int > filterIds () const
 
bool hasFilterId (trigger::TriggerObjectType triggerObjectType) const
 
bool hasFilterId (int triggerObjectType) const
 
bool hasTriggerObjectType (trigger::TriggerObjectType triggerObjectType) const
 Checks, if a certain trigger object type identifier is assigned. More...
 
bool hasTriggerObjectType (int triggerObjectType) const
 
bool id (trigger::TriggerObjectType triggerObjectType) const
 
bool id (int triggerObjectType) const
 
const l1extra::L1EmParticleRef origL1EmRef () const
 
const l1extra::L1EtMissParticleRef origL1EtMissRef () const
 
const L1GctEmCandorigL1GctEmCand () const
 
const L1GctEtHadorigL1GctEtHad () const
 
const L1GctEtMissorigL1GctEtMiss () const
 
const L1GctEtTotalorigL1GctEtTotal () const
 
const L1GctHtMissorigL1GctHtMiss () const
 
const L1GctJetCandorigL1GctJetCand () const
 
const L1MuGMTExtendedCandorigL1GmtMuonCand () const
 
const l1extra::L1JetParticleRef origL1JetRef () const
 
const l1extra::L1MuonParticleRef origL1MuonRef () const
 
const reco::CandidateorigObjCand () const
 
const reco::CandidateBaseReforigObjRef () const
 Special methods for 'l1extra' particles. More...
 
void setCollection (const std::string &collName)
 Methods. More...
 
void setCollection (const edm::InputTag &collName)
 
 TriggerObject ()
 Constructors and Destructor. More...
 
 TriggerObject (const trigger::TriggerObject &trigObj)
 Constructor from trigger::TriggerObject. More...
 
 TriggerObject (const reco::LeafCandidate &leafCand)
 Constructors from base class object. More...
 
 TriggerObject (const reco::CandidateBaseRef &candRef)
 Constructors from base candidate reference (for 'l1extra' particles) More...
 
 TriggerObject (const reco::Particle::LorentzVector &vec, int id=0)
 Constructors from Lorentz-vectors and (optional) PDG ID. More...
 
 TriggerObject (const reco::Particle::PolarLorentzVector &vec, int id=0)
 
std::vector< int > triggerObjectTypes () const
 Get all trigger object type identifiers. More...
 
bool type (trigger::TriggerObjectType triggerObjectType) const
 Calls 'hasTriggerObjectType(...)'. More...
 
bool type (int triggerObjectType) const
 
 ~TriggerObject () override
 Destructor. More...
 
- Public Member Functions inherited from reco::LeafCandidate
Vector boostToCM () const final
 
int charge () const final
 electric charge More...
 
LeafCandidateclone () const override
 returns a clone of the Candidate object More...
 
void construct (int qx3, float pt, float eta, float phi, float mass, const Point &vtx, int pdgId, int status)
 
const Candidatedaughter (size_type) const override
 return daughter at a given position (throws an exception) More...
 
Candidatedaughter (size_type) override
 return daughter at a given position (throws an exception) More...
 
Candidatedaughter (const std::string &s) override
 return daughter with a specified role name More...
 
const Candidatedaughter (const std::string &s) const override
 return daughter with a specified role name More...
 
double energy () const final
 energy More...
 
double et () const final
 transverse energy More...
 
double et2 () const final
 transverse energy squared (use this for cut!) More...
 
double eta () const final
 momentum pseudorapidity More...
 
void fillVertexCovariance (CovarianceMatrix &v) const override
 fill SMatrix More...
 
template<typename T >
T get () const
 get a component More...
 
template<typename T , typename Tag >
T get () const
 get a component More...
 
template<typename T >
T get (size_type i) const
 get a component More...
 
template<typename T , typename Tag >
T get (size_type i) const
 get a component More...
 
bool hasMasterClone () const override
 
bool hasMasterClonePtr () const override
 
bool isCaloMuon () const override
 
bool isConvertedPhoton () const override
 
bool isElectron () const override
 
bool isGlobalMuon () const override
 
bool isJet () const override
 
bool isMuon () const override
 
bool isPhoton () const override
 
bool isStandAloneMuon () const override
 
bool isTrackerMuon () const override
 
 LeafCandidate ()
 
 LeafCandidate (const Candidate &c)
 
template<typename... Args>
 LeafCandidate (Args &&... args)
 
 LeafCandidate (LeafCandidate &rh)
 
 LeafCandidate (LeafCandidate &&)=default
 
 LeafCandidate (LeafCandidate const &)=default
 
bool longLived () const final
 is long lived? More...
 
double mass () const final
 mass More...
 
bool massConstraint () const final
 do mass constraint? More...
 
double massSqr () const final
 mass squared More...
 
const CandidateBaseRefmasterClone () const override
 
const CandidatePtrmasterClonePtr () const override
 
template<typename Ref >
Ref masterRef () const
 cast master clone reference to a concrete type More...
 
Vector momentum () const final
 spatial momentum vector More...
 
const Candidatemother (size_type) const override
 return mother at a given position (throws an exception) More...
 
double mt () const final
 transverse mass More...
 
double mtSqr () const final
 transverse mass squared More...
 
template<typename T >
size_type numberOf () const
 number of components More...
 
template<typename T , typename Tag >
size_type numberOf () const
 number of components More...
 
size_t numberOfDaughters () const override
 number of daughters More...
 
size_t numberOfMothers () const override
 number of mothers More...
 
size_t numberOfSourceCandidatePtrs () const override
 
LeafCandidateoperator= (LeafCandidate &&)=default
 
LeafCandidateoperator= (LeafCandidate const &)=default
 
double p () const final
 magnitude of momentum vector More...
 
const LorentzVectorp4 () const final
 four-momentum Lorentz vector More...
 
int pdgId () const final
 PDG identifier. More...
 
double phi () const final
 momentum azimuthal angle More...
 
const PolarLorentzVectorpolarP4 () const final
 four-momentum Lorentz vector More...
 
double pt () const final
 transverse momentum More...
 
double px () const final
 x coordinate of momentum vector More...
 
double py () const final
 y coordinate of momentum vector More...
 
double pz () const final
 z coordinate of momentum vector More...
 
double rapidity () const final
 rapidity More...
 
void setCharge (Charge q) final
 set electric charge More...
 
void setLongLived () final
 
void setMass (double m) final
 set particle mass More...
 
void setMassConstraint () final
 
void setP4 (const LorentzVector &p4) final
 set 4-momentum More...
 
void setP4 (const PolarLorentzVector &p4) final
 set 4-momentum More...
 
void setPdgId (int pdgId) final
 
void setPz (double pz) final
 
void setStatus (int status) final
 set status word More...
 
void setThreeCharge (Charge qx3) final
 set electric charge More...
 
void setVertex (const Point &vertex) override
 set vertex More...
 
CandidatePtr sourceCandidatePtr (size_type i) const override
 
int status () const final
 status word More...
 
double theta () const final
 momentum polar angle More...
 
int threeCharge () const final
 electric charge More...
 
const Pointvertex () const override
 vertex position (overwritten by PF...) More...
 
double vertexChi2 () const override
 chi-squares More...
 
double vertexCovariance (int i, int j) const override
 (i, j)-th element of error matrix, i, j = 0, ... 2 More...
 
CovarianceMatrix vertexCovariance () const final
 return SMatrix More...
 
double vertexNdof () const override
 
double vertexNormalizedChi2 () const override
 chi-squared divided by n.d.o.f. More...
 
double vx () const override
 x coordinate of vertex position More...
 
double vy () const override
 y coordinate of vertex position More...
 
double vz () const override
 z coordinate of vertex position More...
 
double y () const final
 rapidity More...
 
 ~LeafCandidate () override
 destructor More...
 
- Public Member Functions inherited from reco::Candidate
const_iterator begin () const
 first daughter const_iterator More...
 
iterator begin ()
 first daughter iterator More...
 
virtual const TrackbestTrack () const
 
 Candidate ()
 default constructor More...
 
virtual float dxyError () const
 uncertainty on dxy More...
 
virtual float dzError () const
 uncertainty on dz More...
 
const_iterator end () const
 last daughter const_iterator More...
 
iterator end ()
 last daughter iterator More...
 
template<typename T >
T get () const
 get a component More...
 
template<typename T , typename Tag >
T get () const
 get a component More...
 
template<typename T >
T get (size_type i) const
 get a component More...
 
template<typename T , typename Tag >
T get (size_type i) const
 get a component More...
 
template<typename Ref >
Ref masterRef () const
 cast master clone reference to a concrete type More...
 
template<typename T >
size_type numberOf () const
 number of components More...
 
template<typename T , typename Tag >
size_type numberOf () const
 number of components More...
 
virtual void setSourceCandidatePtr (const CandidatePtr &ptr)
 Set the ptr to the source Candidate. More...
 
virtual ~Candidate ()
 destructor More...
 

Private Member Functions

void addFilterOrCondition (const std::string &name)
 Adds a new HLT filter label or L1 condition name. More...
 
void addPathOrAlgorithm (const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted)
 Adds a new HLT path or L1 algorithm name. More...
 
bool checkIfFiltersAreUnpacked (bool throwIfPacked=true) const
 Check if trigger names have been packed by calling packFilterLabels() and not yet unpacked. More...
 
bool checkIfPathsAreUnpacked (bool throwIfPacked=true) const
 Check if trigger names have been packed by calling packPathNames() and not yet unpacked. More...
 
const std::vector< std::string > & filtersOrConditions () const
 Gets all HLT filter labels or L1 condition names. More...
 
bool hasAnyName (const std::string &name, const std::vector< std::string > &nameVec) const
 Private methods. More...
 
bool hasFilterOrCondition (const std::string &name) const
 Checks, if a certain HLT filter label or L1 condition name is assigned. More...
 
bool hasL3Filter () const
 
bool hasLastFilter () const
 Check, if the usage indicator vectors have been filled. More...
 
bool hasPathOrAlgorithm (const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
 Checks, if a certain HLT path or L1 algorithm name is assigned. More...
 
std::vector< std::string > pathsOrAlgorithms (bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
 Gets all HLT path or L1 algorithm names. More...
 

Private Attributes

std::vector< uint16_t > filterLabelIndices_
 
std::vector< std::string > filterLabels_
 Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in. More...
 
std::vector< uint16_t > pathIndices_
 
std::vector< bool > pathL3FilterAccepted_
 
std::vector< bool > pathLastFilterAccepted_
 
std::vector< std::string > pathNames_
 Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in. More...
 
edm::ParameterSetID psetId_
 

Static Private Attributes

static const char wildcard_ = '*'
 Constants. More...
 

Additional Inherited Members

- Public Types inherited from reco::LeafCandidate
typedef int Charge
 electric charge type More...
 
typedef CandidateCollection daughters
 collection of daughter candidates More...
 
typedef unsigned int index
 
typedef math::XYZTLorentzVector LorentzVector
 Lorentz vector. More...
 
typedef math::XYZPoint Point
 point in the space More...
 
typedef math::PtEtaPhiMLorentzVector PolarLorentzVector
 Lorentz vector. More...
 
typedef math::XYZVector Vector
 point in the space More...
 
- Public Types inherited from reco::Candidate
enum  { dimension = 3 }
 
enum  { size = dimension * (dimension + 1) / 2 }
 matix size More...
 
typedef int Charge
 electric charge type More...
 
typedef candidate::const_iterator const_iterator
 
typedef math::Error< dimension >::type CovarianceMatrix
 covariance error matrix (3x3) More...
 
typedef unsigned int index
 index type More...
 
typedef candidate::iterator iterator
 
typedef math::XYZTLorentzVector LorentzVector
 Lorentz vector. More...
 
typedef math::XYZPoint Point
 point in the space More...
 
typedef math::PtEtaPhiMLorentzVector PolarLorentzVector
 Lorentz vector. More...
 
typedef size_t size_type
 
typedef math::XYZVector Vector
 point in the space More...
 

Detailed Description

Analysis-level trigger object class (stand-alone)

TriggerObjectStandAlone implements a container for trigger objects' information within the 'pat' namespace. These Trigger objects keep also information on filters and paths to be saved independently or embedded into PAT objects. The TriggerObjectStandAlone is also the data format used in the PAT trigger object matching. For detailed information, consult https://twiki.cern.ch/twiki/bin/view/CMS/SWGuidePATTrigger#TriggerObjectStandAlone

Author
Volker Adler

Definition at line 32 of file TriggerObjectStandAlone.h.

Constructor & Destructor Documentation

◆ TriggerObjectStandAlone() [1/7]

TriggerObjectStandAlone::TriggerObjectStandAlone ( )

Constructors and Destructor.

Default constructor

Definition at line 24 of file TriggerObjectStandAlone.cc.

References filterLabelIndices_, filterLabels_, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

24  : TriggerObject() {
25  filterLabels_.clear();
26  filterLabelIndices_.clear();
27  pathNames_.clear();
29  pathL3FilterAccepted_.clear();
30 }
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
TriggerObject()
Constructors and Destructor.
std::vector< bool > pathL3FilterAccepted_

◆ TriggerObjectStandAlone() [2/7]

TriggerObjectStandAlone::TriggerObjectStandAlone ( const TriggerObject trigObj)

Constructor from pat::TriggerObject.

Definition at line 33 of file TriggerObjectStandAlone.cc.

References filterLabelIndices_, filterLabels_, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

33  : TriggerObject(trigObj) {
34  filterLabels_.clear();
35  filterLabelIndices_.clear();
36  pathNames_.clear();
38  pathL3FilterAccepted_.clear();
39 }
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
TriggerObject()
Constructors and Destructor.
std::vector< bool > pathL3FilterAccepted_

◆ TriggerObjectStandAlone() [3/7]

TriggerObjectStandAlone::TriggerObjectStandAlone ( const trigger::TriggerObject trigObj)

Constructor from trigger::TriggerObject.

Definition at line 42 of file TriggerObjectStandAlone.cc.

References filterLabelIndices_, filterLabels_, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

42  : TriggerObject(trigObj) {
43  filterLabels_.clear();
44  filterLabelIndices_.clear();
45  pathNames_.clear();
47  pathL3FilterAccepted_.clear();
48 }
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
TriggerObject()
Constructors and Destructor.
std::vector< bool > pathL3FilterAccepted_

◆ TriggerObjectStandAlone() [4/7]

TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::LeafCandidate leafCand)

Constructor from reco::Candidate.

Definition at line 51 of file TriggerObjectStandAlone.cc.

References filterLabelIndices_, filterLabels_, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

51  : TriggerObject(leafCand) {
52  filterLabels_.clear();
53  filterLabelIndices_.clear();
54  pathNames_.clear();
56  pathL3FilterAccepted_.clear();
57 }
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
TriggerObject()
Constructors and Destructor.
std::vector< bool > pathL3FilterAccepted_

◆ TriggerObjectStandAlone() [5/7]

TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::Particle::LorentzVector vec,
int  id = 0 
)

Constructors from Lorentz-vectors and (optional) PDG ID.

Definition at line 60 of file TriggerObjectStandAlone.cc.

References filterLabelIndices_, filterLabels_, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

61  : TriggerObject(vec, id) {
62  filterLabels_.clear();
63  filterLabelIndices_.clear();
64  pathNames_.clear();
66  pathL3FilterAccepted_.clear();
67 }
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
TriggerObject()
Constructors and Destructor.
std::vector< bool > pathL3FilterAccepted_

◆ TriggerObjectStandAlone() [6/7]

TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::Particle::PolarLorentzVector vec,
int  id = 0 
)

Definition at line 68 of file TriggerObjectStandAlone.cc.

References filterLabelIndices_, filterLabels_, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

69  : TriggerObject(vec, id) {
70  filterLabels_.clear();
71  filterLabelIndices_.clear();
72  pathNames_.clear();
74  pathL3FilterAccepted_.clear();
75 }
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
TriggerObject()
Constructors and Destructor.
std::vector< bool > pathL3FilterAccepted_

◆ TriggerObjectStandAlone() [7/7]

pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( const TriggerObjectStandAlone )
default

◆ ~TriggerObjectStandAlone()

pat::TriggerObjectStandAlone::~TriggerObjectStandAlone ( )
inlineoverride

Destructor.

Definition at line 114 of file TriggerObjectStandAlone.h.

114 {};

Member Function Documentation

◆ addAlgorithmName()

void pat::TriggerObjectStandAlone::addAlgorithmName ( const std::string &  algorithmName,
bool  algoCondAccepted = true 
)
inline

Adds a new L1 algorithm name.

Definition at line 131 of file TriggerObjectStandAlone.h.

References addPathOrAlgorithm().

131  {
132  addPathOrAlgorithm(algorithmName, algoCondAccepted, false);
133  };
void addPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted)
Adds a new HLT path or L1 algorithm name.

◆ addConditionName()

void pat::TriggerObjectStandAlone::addConditionName ( const std::string &  conditionName)
inline

Adds a new L1 condition name.

Definition at line 123 of file TriggerObjectStandAlone.h.

References addFilterOrCondition().

123 { addFilterOrCondition(conditionName); };
void addFilterOrCondition(const std::string &name)
Adds a new HLT filter label or L1 condition name.

◆ addFilterLabel()

void pat::TriggerObjectStandAlone::addFilterLabel ( const std::string &  filterLabel)
inline

Adds a new HLT filter label.

Definition at line 121 of file TriggerObjectStandAlone.h.

References addFilterOrCondition(), and HLT_2023v12_cff::filterLabel.

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

void addFilterOrCondition(const std::string &name)
Adds a new HLT filter label or L1 condition name.

◆ addFilterOrCondition()

void pat::TriggerObjectStandAlone::addFilterOrCondition ( const std::string &  name)
inlineprivate

Adds a new HLT filter label or L1 condition name.

Definition at line 67 of file TriggerObjectStandAlone.h.

References filterLabels_, hasFilterOrCondition(), and Skims_PA_cff::name.

Referenced by addConditionName(), and addFilterLabel().

67  {
69  filterLabels_.push_back(name);
70  };
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
bool hasFilterOrCondition(const std::string &name) const
Checks, if a certain HLT filter label or L1 condition name is assigned.

◆ addPathName()

void pat::TriggerObjectStandAlone::addPathName ( const std::string &  pathName,
bool  pathLastFilterAccepted = true,
bool  pathL3FilterAccepted = true 
)
inline

Adds a new HLT path name.

Definition at line 125 of file TriggerObjectStandAlone.h.

References addPathOrAlgorithm(), and hltMonBTagIPClient_cfi::pathName.

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

127  {
128  addPathOrAlgorithm(pathName, pathLastFilterAccepted, pathL3FilterAccepted);
129  };
void addPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted)
Adds a new HLT path or L1 algorithm name.

◆ addPathOrAlgorithm()

void TriggerObjectStandAlone::addPathOrAlgorithm ( const std::string &  name,
bool  pathLastFilterAccepted,
bool  pathL3FilterAccepted 
)
private

Adds a new HLT path or L1 algorithm name.

Definition at line 129 of file TriggerObjectStandAlone.cc.

References checkIfPathsAreUnpacked(), hasPathOrAlgorithm(), Skims_PA_cff::name, pathL3FilterAccepted_, pathLastFilterAccepted_, and pathNames_.

Referenced by addAlgorithmName(), and addPathName().

131  {
133 
134  // Check, if path is already assigned
135  if (!hasPathOrAlgorithm(name, false, false)) {
136  // The path itself
137  pathNames_.push_back(name);
138  // The corresponding usage of the trigger objects
139  pathLastFilterAccepted_.push_back(pathLastFilterAccepted);
140  pathL3FilterAccepted_.push_back(pathL3FilterAccepted);
141  // Enable status updates
142  } else if (pathLastFilterAccepted || pathL3FilterAccepted) {
143  // Search for path
144  unsigned index(0);
145  while (index < pathNames_.size()) {
146  if (pathNames_.at(index) == name)
147  break;
148  ++index;
149  }
150  // Status update
151  if (index < pathNames_.size()) {
152  pathLastFilterAccepted_.at(index) = pathLastFilterAccepted_.at(index) || pathLastFilterAccepted;
153  pathL3FilterAccepted_.at(index) = pathL3FilterAccepted_.at(index) || pathL3FilterAccepted;
154  }
155  }
156 }
bool checkIfPathsAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packPathNames() and not yet unpacked.
unsigned int index
Definition: LeafCandidate.h:31
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
bool hasPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Checks, if a certain HLT path or L1 algorithm name is assigned.
std::vector< bool > pathL3FilterAccepted_

◆ algo()

bool pat::TriggerObjectStandAlone::algo ( const std::string &  algorithmName,
unsigned  algoCondAccepted = 1 
) const
inline

Calls 'hasAlgorithmName(...)'.

Definition at line 185 of file TriggerObjectStandAlone.h.

References hasAlgorithmName().

185  {
186  return hasAlgorithmName(algorithmName, bool(algoCondAccepted));
187  };
bool hasAlgorithmName(const std::string &algorithmName, bool algoCondAccepted=true) const
Checks, if a certain L1 algorithm name is assigned.

◆ algorithmNames()

std::vector<std::string> pat::TriggerObjectStandAlone::algorithmNames ( bool  algoCondAccepted = true) const
inline

Gets all L1 algorithm names.

Definition at line 143 of file TriggerObjectStandAlone.h.

References pathsOrAlgorithms().

143  {
144  return pathsOrAlgorithms(algoCondAccepted, false);
145  };
std::vector< std::string > pathsOrAlgorithms(bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Gets all HLT path or L1 algorithm names.

◆ allLabels()

std::vector< std::string > const * TriggerObjectStandAlone::allLabels ( edm::ParameterSetID const &  psetid,
const edm::EventBase event,
const edm::TriggerResults res 
) const

Definition at line 396 of file TriggerObjectStandAlone.cc.

References edmTracerLogToSimpleConfig::allModules, mps_fire::i, callgraph::module, dqmiodumpmetadata::n, muonDTDigis_cfi::pset, edm::path_configuration::removeSchedulingTokensFromModuleLabel(), runTheMatrix::ret, PDWG_EXODelayedJetMET_cff::saveTags, and L1TEGammaOffline_cfi::triggerNames.

Referenced by packFilterLabels(), and unpackFilterLabels().

398  {
399  // If TriggerNames was already created and cached here in the map,
400  // then look it up and return that one
401  AllLabelsMap::const_iterator iter = allLabelsMap.find(psetid);
402  if (iter != allLabelsMap.end()) {
403  return &iter->second;
404  }
405 
406  const auto &triggerNames = event.triggerNames(res);
407  edm::ParameterSet const *pset = nullptr;
408  //getting the ParameterSet from the event ensures that the registry is filled
409  if (nullptr != (pset = event.parameterSet(psetid))) {
410  using namespace std;
411  using namespace edm;
412  using namespace trigger;
413 
414  const unsigned int n(triggerNames.size());
415  std::set<std::string> saveTags;
416  for (unsigned int i = 0; i != n; ++i) {
417  if (pset->existsAs<vector<string>>(triggerNames.triggerName(i), true)) {
418  auto const &modules = pset->getParameter<vector<string>>(triggerNames.triggerName(i));
419  for (auto const &module : modules) {
421  if (pset->exists(moduleStrip)) {
422  const auto &modulePSet = pset->getParameterSet(moduleStrip);
423  if (modulePSet.existsAs<bool>("saveTags", true) and modulePSet.getParameter<bool>("saveTags")) {
424  saveTags.insert(moduleStrip);
425  }
426  }
427  }
428  }
429  }
430  std::vector<std::string> allModules(saveTags.begin(), saveTags.end());
431  std::pair<AllLabelsMap::iterator, bool> ret =
432  allLabelsMap.insert(std::pair<edm::ParameterSetID, std::vector<std::string>>(psetid, allModules));
433  return &(ret.first->second);
434  }
435  return nullptr;
436 }
ret
prodAgent to be discontinued
std::string removeSchedulingTokensFromModuleLabel(std::string iLabel)
Definition: Electron.h:6
HLT enums.
Definition: event.py:1

◆ checkIfFiltersAreUnpacked()

bool TriggerObjectStandAlone::checkIfFiltersAreUnpacked ( bool  throwIfPacked = true) const
private

Check if trigger names have been packed by calling packFilterLabels() and not yet unpacked.

Definition at line 269 of file TriggerObjectStandAlone.cc.

References Exception, and filterLabelIndices_.

Referenced by filtersOrConditions(), and hasFilterOrCondition().

269  {
270  bool unpacked = filterLabelIndices_.empty();
271  if (!unpacked && throwIfPacked)
272  throw cms::Exception("RuntimeError",
273  "This TriggerObjectStandAlone object has packed trigger filter labels. Before accessing path "
274  "names you must call unpackFilterLabels with an edm::EventBase object. Both the edm::Event or "
275  "fwlite::Event are derived from edm::EventBase and can be passed\n");
276  return unpacked;
277 }
std::vector< uint16_t > filterLabelIndices_

◆ checkIfPathsAreUnpacked()

bool TriggerObjectStandAlone::checkIfPathsAreUnpacked ( bool  throwIfPacked = true) const
private

Check if trigger names have been packed by calling packPathNames() and not yet unpacked.

Definition at line 260 of file TriggerObjectStandAlone.cc.

References Exception, pathIndices_, and pathNames_.

Referenced by addPathOrAlgorithm(), hasPathOrAlgorithm(), and pathsOrAlgorithms().

260  {
261  bool unpacked = (!pathNames_.empty() || pathIndices_.empty());
262  if (!unpacked && throwIfPacked)
263  throw cms::Exception("RuntimeError",
264  "This TriggerObjectStandAlone object has packed trigger path names. Before accessing path "
265  "names you must call unpackPathNames with an edm::TriggerNames object. You can get the latter "
266  "from the edm::Event or fwlite::Event and the TriggerResults\n");
267  return unpacked;
268 }
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< uint16_t > pathIndices_

◆ coll()

bool pat::TriggerObjectStandAlone::coll ( const std::string &  collName) const
inlineoverridevirtual

Calls 'hasCollection(...)' (method override)

Reimplemented from pat::TriggerObject.

Definition at line 189 of file TriggerObjectStandAlone.h.

References trigObjTnPSource_cfi::collName, and hasCollection().

189 { return hasCollection(collName); };
bool hasCollection(const std::string &collName) const override
Checks, if a certain label of original collection is assigned (method overrides)

◆ cond()

bool pat::TriggerObjectStandAlone::cond ( const std::string &  conditionName) const
inline

Calls 'hasConditionName(...)'.

Definition at line 177 of file TriggerObjectStandAlone.h.

References hasConditionName().

177 { return hasConditionName(conditionName); };
bool hasConditionName(const std::string &conditionName) const
Checks, if a certain L1 condition name is assigned.

◆ conditionNames()

const std::vector<std::string>& pat::TriggerObjectStandAlone::conditionNames ( ) const
inline

Gets all L1 condition names.

Definition at line 137 of file TriggerObjectStandAlone.h.

References filtersOrConditions().

137 { return filtersOrConditions(); };
const std::vector< std::string > & filtersOrConditions() const
Gets all HLT filter labels or L1 condition names.

◆ copy()

TriggerObjectStandAlone pat::TriggerObjectStandAlone::copy ( ) const
inline

Methods.

Definition at line 118 of file TriggerObjectStandAlone.h.

Referenced by SequenceTypes._TaskBase::copyAndAdd().

118 { return *this; }

◆ filter()

bool pat::TriggerObjectStandAlone::filter ( const std::string &  filterLabel) const
inline

Calls 'hasFilterLabel(...)'.

Special methods for the cut string parser

  • argument types usable in the cut string parser
  • short names for readable configuration files

Definition at line 175 of file TriggerObjectStandAlone.h.

References HLT_2023v12_cff::filterLabel, and hasFilterLabel().

175 { return hasFilterLabel(filterLabel); };
bool hasFilterLabel(const std::string &filterLabel) const
Checks, if a certain HLT filter label is assigned.

◆ filterLabels()

const std::vector<std::string>& pat::TriggerObjectStandAlone::filterLabels ( ) const
inline

Gets all HLT filter labels.

Definition at line 135 of file TriggerObjectStandAlone.h.

References filtersOrConditions().

135 { return filtersOrConditions(); };
const std::vector< std::string > & filtersOrConditions() const
Gets all HLT filter labels or L1 condition names.

◆ filtersOrConditions()

const std::vector<std::string>& pat::TriggerObjectStandAlone::filtersOrConditions ( ) const
inlineprivate

Gets all HLT filter labels or L1 condition names.

Definition at line 74 of file TriggerObjectStandAlone.h.

References checkIfFiltersAreUnpacked(), and filterLabels_.

Referenced by conditionNames(), and filterLabels().

74  {
76  return filterLabels_;
77  };
bool checkIfFiltersAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packFilterLabels() and not yet unpacked...
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...

◆ hasAlgoCondAccepted()

bool pat::TriggerObjectStandAlone::hasAlgoCondAccepted ( ) const
inline

Definition at line 167 of file TriggerObjectStandAlone.h.

References hasLastFilter().

167 { return hasLastFilter(); };
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.

◆ hasAlgorithmName()

bool pat::TriggerObjectStandAlone::hasAlgorithmName ( const std::string &  algorithmName,
bool  algoCondAccepted = true 
) const
inline

Checks, if a certain L1 algorithm name is assigned.

Definition at line 159 of file TriggerObjectStandAlone.h.

References hasPathOrAlgorithm().

Referenced by algo().

159  {
160  return hasPathOrAlgorithm(algorithmName, algoCondAccepted, false);
161  };
bool hasPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Checks, if a certain HLT path or L1 algorithm name is assigned.

◆ hasAnyName()

bool TriggerObjectStandAlone::hasAnyName ( const std::string &  name,
const std::vector< std::string > &  nameVec 
) const
private

Private methods.

Checks a string vector for occurence of a certain string, incl. wild-card mechanism

Definition at line 80 of file TriggerObjectStandAlone.cc.

References runEdmFileComparison::failed, Skims_PA_cff::name, submitPVValidationJobs::split(), AlCaHLTBitMon_QueryRunRegistry::string, and wildcard_.

Referenced by hasCollection(), hasFilterOrCondition(), and hasPathOrAlgorithm().

80  {
81  // Special cases first
82  // Always false for empty vector to check
83  if (nameVec.empty())
84  return false;
85  // Always true for general wild-card(s)
86  if (name.find_first_not_of(wildcard_) == std::string::npos)
87  return true;
88  // Split name to evaluate in parts, seperated by wild-cards
89  std::vector<std::string> namePartsVec;
90  boost::split(namePartsVec, name, boost::is_any_of(std::string(1, wildcard_)), boost::token_compress_on);
91  // Iterate over vector of names to search
92  for (std::vector<std::string>::const_iterator iVec = nameVec.begin(); iVec != nameVec.end(); ++iVec) {
93  // Not failed yet
94  bool failed(false);
95  // Start searching at the first character
96  size_type index(0);
97  // Iterate over evaluation name parts
98  for (std::vector<std::string>::const_iterator iName = namePartsVec.begin(); iName != namePartsVec.end(); ++iName) {
99  // Empty parts due to
100  // - wild-card at beginning/end or
101  // - multiple wild-cards (should be supressed by 'boost::token_compress_on')
102  if (iName->length() == 0)
103  continue;
104  // Search from current index and
105  // set index to found occurence
106  index = iVec->find(*iName, index);
107  // Failed and exit loop, if
108  // - part not found
109  // - part at beginning not found there
110  if (index == std::string::npos || (iName == namePartsVec.begin() && index > 0)) {
111  failed = true;
112  break;
113  }
114  // Increase index by length of found part
115  index += iName->length();
116  }
117  // Failed, if end of name not reached
118  if (index < iVec->length() && namePartsVec.back().length() != 0)
119  failed = true;
120  // Match found!
121  if (!failed)
122  return true;
123  }
124  // No match found!
125  return false;
126 }
static const char wildcard_
Constants.
uint16_t size_type
unsigned int index
Definition: LeafCandidate.h:31

◆ hasCollection() [1/2]

bool TriggerObjectStandAlone::hasCollection ( const std::string &  collName) const
overridevirtual

Checks, if a certain label of original collection is assigned (method overrides)

Reimplemented from pat::TriggerObject.

Definition at line 236 of file TriggerObjectStandAlone.cc.

References pat::TriggerObject::collection(), trigObjTnPSource_cfi::collName, hasAnyName(), pat::TriggerObject::hasCollection(), edm::InputTag::instance(), edm::InputTag::label(), edm::InputTag::process(), and wildcard_.

Referenced by coll(), and pat::PATTriggerProducer::produce().

236  {
237  // Move to wild-card parser, if needed only
238  if (collName.find(wildcard_) != std::string::npos) {
239  // True, if collection name is simply fine
240  if (hasAnyName(collName, std::vector<std::string>(1, collection())))
241  return true;
242  // Check, if collection name possibly fits in an edm::InputTag approach
243  const edm::InputTag collectionTag(collection());
244  const edm::InputTag collTag(collName);
245  // If evaluated collection tag contains a process name, it must have been found already by identity check
246  if (collTag.process().empty()) {
247  // Check instance ...
248  if ((collTag.instance().empty() && collectionTag.instance().empty()) ||
249  hasAnyName(collTag.instance(), std::vector<std::string>(1, collectionTag.instance()))) {
250  // ... and label
251  return hasAnyName(collTag.label(), std::vector<std::string>(1, collectionTag.label()));
252  }
253  }
254  return false;
255  }
256  // Use parent class's method otherwise
258 }
static const char wildcard_
Constants.
virtual bool hasCollection(const std::string &collName) const
Checks, if a certain label of original collection is assigned.
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
const std::string & collection() const
Get the label of the collection the trigger object originates from.
Definition: TriggerObject.h:96

◆ hasCollection() [2/2]

bool pat::TriggerObjectStandAlone::hasCollection ( const edm::InputTag collName) const
inlineoverridevirtual

Reimplemented from pat::TriggerObject.

Definition at line 164 of file TriggerObjectStandAlone.h.

References trigObjTnPSource_cfi::collName, and hasCollection().

Referenced by hasCollection().

164 { return hasCollection(collName.encode()); };
bool hasCollection(const std::string &collName) const override
Checks, if a certain label of original collection is assigned (method overrides)

◆ hasConditionName()

bool pat::TriggerObjectStandAlone::hasConditionName ( const std::string &  conditionName) const
inline

Checks, if a certain L1 condition name is assigned.

Definition at line 151 of file TriggerObjectStandAlone.h.

References hasFilterOrCondition().

Referenced by cond().

151 { return hasFilterOrCondition(conditionName); };
bool hasFilterOrCondition(const std::string &name) const
Checks, if a certain HLT filter label or L1 condition name is assigned.

◆ hasFilterLabel()

bool pat::TriggerObjectStandAlone::hasFilterLabel ( const std::string &  filterLabel) const
inline

Checks, if a certain HLT filter label is assigned.

Definition at line 149 of file TriggerObjectStandAlone.h.

References HLT_2023v12_cff::filterLabel, and hasFilterOrCondition().

Referenced by filter().

149 { return hasFilterOrCondition(filterLabel); };
bool hasFilterOrCondition(const std::string &name) const
Checks, if a certain HLT filter label or L1 condition name is assigned.

◆ hasFilterOrCondition()

bool TriggerObjectStandAlone::hasFilterOrCondition ( const std::string &  name) const
private

Checks, if a certain HLT filter label or L1 condition name is assigned.

Definition at line 184 of file TriggerObjectStandAlone.cc.

References checkIfFiltersAreUnpacked(), filterLabels_, spr::find(), hasAnyName(), Skims_PA_cff::name, and wildcard_.

Referenced by addFilterOrCondition(), hasConditionName(), and hasFilterLabel().

184  {
186 
187  // Move to wild-card parser, if needed
188  if (name.find(wildcard_) != std::string::npos)
189  return hasAnyName(name, filterLabels_);
190  // Return, if filter label is assigned
191  return (std::find(filterLabels_.begin(), filterLabels_.end(), name) != filterLabels_.end());
192 }
static const char wildcard_
Constants.
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
bool checkIfFiltersAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packFilterLabels() and not yet unpacked...
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...

◆ hasL3Filter()

bool pat::TriggerObjectStandAlone::hasL3Filter ( ) const
inlineprivate

Definition at line 88 of file TriggerObjectStandAlone.h.

References pathL3FilterAccepted_, and pathNames_.

Referenced by hasPathL3FilterAccepted(), hasPathOrAlgorithm(), and pathsOrAlgorithms().

88  {
89  return (!pathL3FilterAccepted_.empty() && pathL3FilterAccepted_.size() == pathNames_.size());
90  };
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< bool > pathL3FilterAccepted_

◆ hasLastFilter()

bool pat::TriggerObjectStandAlone::hasLastFilter ( ) const
inlineprivate

Check, if the usage indicator vectors have been filled.

Definition at line 85 of file TriggerObjectStandAlone.h.

References pathLastFilterAccepted_, and pathNames_.

Referenced by hasAlgoCondAccepted(), hasPathLastFilterAccepted(), hasPathOrAlgorithm(), and pathsOrAlgorithms().

85  {
86  return (!pathLastFilterAccepted_.empty() && pathLastFilterAccepted_.size() == pathNames_.size());
87  };
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...

◆ hasPathL3FilterAccepted()

bool pat::TriggerObjectStandAlone::hasPathL3FilterAccepted ( ) const
inline

Definition at line 168 of file TriggerObjectStandAlone.h.

References hasL3Filter().

168 { return hasL3Filter(); };

◆ hasPathLastFilterAccepted()

bool pat::TriggerObjectStandAlone::hasPathLastFilterAccepted ( ) const
inline

Checks, if the usage indicator vector has been filled.

Definition at line 166 of file TriggerObjectStandAlone.h.

References hasLastFilter().

166 { return hasLastFilter(); };
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.

◆ hasPathName()

bool pat::TriggerObjectStandAlone::hasPathName ( const std::string &  pathName,
bool  pathLastFilterAccepted = false,
bool  pathL3FilterAccepted = true 
) const
inline

Checks, if a certain HLT path name is assigned.

Definition at line 153 of file TriggerObjectStandAlone.h.

References hasPathOrAlgorithm(), and hltMonBTagIPClient_cfi::pathName.

Referenced by path().

155  {
156  return hasPathOrAlgorithm(pathName, pathLastFilterAccepted, pathL3FilterAccepted);
157  };
bool hasPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Checks, if a certain HLT path or L1 algorithm name is assigned.

◆ hasPathOrAlgorithm()

bool TriggerObjectStandAlone::hasPathOrAlgorithm ( const std::string &  name,
bool  pathLastFilterAccepted,
bool  pathL3FilterAccepted 
) const
private

Checks, if a certain HLT path or L1 algorithm name is assigned.

Definition at line 195 of file TriggerObjectStandAlone.cc.

References checkIfPathsAreUnpacked(), spr::find(), hasAnyName(), hasL3Filter(), hasLastFilter(), Skims_PA_cff::name, pathL3FilterAccepted_, pathLastFilterAccepted_, pathNames_, pathsOrAlgorithms(), and wildcard_.

Referenced by addPathOrAlgorithm(), hasAlgorithmName(), and hasPathName().

197  {
199 
200  // Move to wild-card parser, if needed
201  if (name.find(wildcard_) != std::string::npos)
202  return hasAnyName(name, pathsOrAlgorithms(pathLastFilterAccepted, pathL3FilterAccepted));
203  // Deal with older PAT-tuples, where trigger object usage is not available
204  if (!hasLastFilter())
205  pathLastFilterAccepted = false;
206  if (!hasL3Filter())
207  pathL3FilterAccepted = false;
208  // Check, if path name is assigned at all
209  std::vector<std::string>::const_iterator match(std::find(pathNames_.begin(), pathNames_.end(), name));
210  // False, if path name not assigned
211  if (match == pathNames_.end())
212  return false;
213  if (!pathLastFilterAccepted && !pathL3FilterAccepted)
214  return true;
215  bool foundLastFilter(pathLastFilterAccepted ? pathLastFilterAccepted_.at(match - pathNames_.begin()) : true);
216  bool foundL3Filter(pathL3FilterAccepted ? pathL3FilterAccepted_.at(match - pathNames_.begin()) : true);
217  // Return for assigned path name, if trigger object usage meets requirement
218  return (foundLastFilter && foundL3Filter);
219 }
static const char wildcard_
Constants.
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
bool checkIfPathsAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packPathNames() and not yet unpacked.
std::vector< bool > pathLastFilterAccepted_
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< std::string > pathsOrAlgorithms(bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Gets all HLT path or L1 algorithm names.
std::vector< bool > pathL3FilterAccepted_

◆ packFilterLabels() [1/2]

void TriggerObjectStandAlone::packFilterLabels ( const edm::EventBase event,
const edm::TriggerResults res 
)

Definition at line 377 of file TriggerObjectStandAlone.cc.

References allLabels(), and psetId_.

377  {
379 }
void packFilterLabels(const edm::EventBase &event, const edm::TriggerResults &res)
std::vector< std::string > const * allLabels(edm::ParameterSetID const &psetid, const edm::EventBase &event, const edm::TriggerResults &res) const
Definition: Electron.h:6
Definition: event.py:1

◆ packFilterLabels() [2/2]

void TriggerObjectStandAlone::packFilterLabels ( const std::vector< std::string > &  labels)

pack filter labels into indices; note that the labels must be sorted!

Definition at line 328 of file TriggerObjectStandAlone.cc.

References Exception, filterLabelIndices_, filterLabels_, mps_fire::i, dqmdumpme::indices, pfDeepBoostedJetPreprocessParams_cfi::lower_bound, eostools::move(), dqmiodumpmetadata::n, names, and jetUpdater_cfi::sort.

328  {
329  if (!filterLabelIndices_.empty()) {
330  throw cms::Exception("RuntimeError",
331  "Error, trying to pack filter labels for an already packed TriggerObjectStandAlone");
332  }
333  std::vector<std::string> unmatched;
334  std::vector<uint16_t> indices;
335  indices.reserve(filterLabels_.size());
336 
337  auto nStart = names.begin(), nEnd = names.end();
338  for (unsigned int i = 0, n = filterLabels_.size(); i < n; ++i) {
339  auto match = std::lower_bound(nStart, nEnd, filterLabels_[i]);
340  if (match != nEnd && *match == filterLabels_[i]) {
341  indices.push_back(match - nStart);
342  } else {
343  static std::atomic<int> _warn(0);
344  if (++_warn < 5)
345  edm::LogWarning("TriggerObjectStandAlone::packFilterLabels()")
346  << "Warning: can't resolve '" << filterLabels_[i] << "' to a label index. idx: " << i << std::endl;
347  unmatched.push_back(std::move(filterLabels_[i]));
348  }
349  }
350  std::sort(indices.begin(), indices.end()); // try reduce enthropy
352  filterLabels_.swap(unmatched);
353 }
std::vector< uint16_t > filterLabelIndices_
const std::string names[nVars_]
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
Log< level::Warning, false > LogWarning
def move(src, dest)
Definition: eostools.py:511

◆ packP4()

void TriggerObjectStandAlone::packP4 ( )

reduce the precision on the 4-vector

Definition at line 381 of file TriggerObjectStandAlone.cc.

References reco::LeafCandidate::eta(), reco::LeafCandidate::mass(), reco::LeafCandidate::phi(), reco::LeafCandidate::pt(), and reco::LeafCandidate::setP4().

381  {
382  setP4(reco::Particle::PolarLorentzVector(MiniFloatConverter::reduceMantissaToNbitsRounding<14>(pt()),
383  MiniFloatConverter::reduceMantissaToNbitsRounding<11>(eta()),
384  MiniFloatConverter::reduceMantissaToNbits<11>(phi()),
385  MiniFloatConverter::reduceMantissaToNbitsRounding<8>(mass())));
386 }
double pt() const final
transverse momentum
double mass() const final
mass
math::PtEtaPhiMLorentzVector PolarLorentzVector
Lorentz vector.
Definition: Particle.h:23
double phi() const final
momentum azimuthal angle
void setP4(const LorentzVector &p4) final
set 4-momentum
double eta() const final
momentum pseudorapidity

◆ packPathNames()

void TriggerObjectStandAlone::packPathNames ( const edm::TriggerNames names)

pack trigger names into indices

Definition at line 279 of file TriggerObjectStandAlone.cc.

References reco::Candidate::end(), Exception, mps_fire::i, pat::TriggerObject::id(), dqmdumpme::indices, dqmiodumpmetadata::n, names, convertSQLiteXML::ok, pathIndices_, and pathNames_.

279  {
280  if (!pathIndices_.empty()) {
281  if (!pathNames_.empty()) {
282  throw cms::Exception("RuntimeError", "Error, trying to pack a partially packed TriggerObjectStandAlone");
283  } else {
284  return;
285  }
286  }
287  bool ok = true;
288  unsigned int n = pathNames_.size(), end = names.size();
289  std::vector<uint16_t> indices(n);
290  for (unsigned int i = 0; i < n; ++i) {
291  uint16_t id = names.triggerIndex(pathNames_[i]);
292  if (id >= end) {
293  static std::atomic<int> _warn(0);
294  if (++_warn < 5)
295  edm::LogWarning("TriggerObjectStandAlone::packPathNames()")
296  << "Warning: can't resolve '" << pathNames_[i] << "' to a path index" << std::endl;
297  ok = false;
298  break;
299  } else {
300  indices[i] = id;
301  }
302  }
303  if (ok) {
304  pathIndices_.swap(indices);
305  pathNames_.clear();
306  }
307 }
const std::string names[nVars_]
const_iterator end() const
last daughter const_iterator
Definition: Candidate.h:145
bool id(trigger::TriggerObjectType triggerObjectType) const
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
Log< level::Warning, false > LogWarning
std::vector< uint16_t > pathIndices_

◆ path()

bool pat::TriggerObjectStandAlone::path ( const std::string &  pathName,
unsigned  pathLastFilterAccepted = 0,
unsigned  pathL3FilterAccepted = 1 
) const
inline

Calls 'hasPathName(...)'.

Definition at line 179 of file TriggerObjectStandAlone.h.

References hasPathName(), and hltMonBTagIPClient_cfi::pathName.

181  {
182  return hasPathName(pathName, bool(pathLastFilterAccepted), bool(pathL3FilterAccepted));
183  };
bool hasPathName(const std::string &pathName, bool pathLastFilterAccepted=false, bool pathL3FilterAccepted=true) const
Checks, if a certain HLT path name is assigned.

◆ pathNames()

std::vector<std::string> pat::TriggerObjectStandAlone::pathNames ( bool  pathLastFilterAccepted = false,
bool  pathL3FilterAccepted = true 
) const
inline

Gets all HLT path names.

Definition at line 139 of file TriggerObjectStandAlone.h.

References pathsOrAlgorithms().

139  {
140  return pathsOrAlgorithms(pathLastFilterAccepted, pathL3FilterAccepted);
141  };
std::vector< std::string > pathsOrAlgorithms(bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Gets all HLT path or L1 algorithm names.

◆ pathsOrAlgorithms()

std::vector< std::string > TriggerObjectStandAlone::pathsOrAlgorithms ( bool  pathLastFilterAccepted,
bool  pathL3FilterAccepted 
) const
private

Gets all HLT path or L1 algorithm names.

Definition at line 159 of file TriggerObjectStandAlone.cc.

References checkIfPathsAreUnpacked(), hasL3Filter(), hasLastFilter(), pathL3FilterAccepted_, pathLastFilterAccepted_, pathNames_, and Skims_PA_cff::paths.

Referenced by algorithmNames(), hasPathOrAlgorithm(), and pathNames().

160  {
162 
163  // Deal with older PAT-tuples, where trigger object usage is not available
164  if (!hasLastFilter())
165  pathLastFilterAccepted = false;
166  if (!hasL3Filter())
167  pathL3FilterAccepted = false;
168  // All path names, if usage not restricted (not required or not available)
169  if (!pathLastFilterAccepted && !pathL3FilterAccepted)
170  return pathNames_;
171  // Temp vector of path names
172  std::vector<std::string> paths;
173  // Loop over usage vector and fill corresponding paths into temp vector
174  for (unsigned iPath = 0; iPath < pathNames_.size(); ++iPath) {
175  if ((!pathLastFilterAccepted || pathLastFilterAccepted_.at(iPath)) &&
176  (!pathL3FilterAccepted || pathL3FilterAccepted_.at(iPath)))
177  paths.push_back(pathNames_.at(iPath)); // order matters in order to protect from empty vectors in old data
178  }
179  // Return temp vector
180  return paths;
181 }
bool checkIfPathsAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packPathNames() and not yet unpacked.
std::vector< bool > pathLastFilterAccepted_
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< bool > pathL3FilterAccepted_

◆ psetID()

const edm::ParameterSetID& pat::TriggerObjectStandAlone::psetID ( ) const
inline

Definition at line 194 of file TriggerObjectStandAlone.h.

References psetId_.

194 { return psetId_; }

◆ setPSetID()

void pat::TriggerObjectStandAlone::setPSetID ( const edm::ParameterSetID psetId)
inline

set the psetid of the trigger process

Definition at line 192 of file TriggerObjectStandAlone.h.

References psetId_.

192 { psetId_ = psetId; }

◆ triggerObject()

TriggerObject TriggerObjectStandAlone::triggerObject ( )

Gets the pat::TriggerObject (parent class)

Definition at line 224 of file TriggerObjectStandAlone.cc.

References pat::TriggerObject::addTriggerObjectType(), pat::TriggerObject::collection(), mps_fire::i, reco::LeafCandidate::p4(), reco::LeafCandidate::pdgId(), pat::TriggerObject::setCollection(), and pat::TriggerObject::triggerObjectTypes().

224  {
225  // Create a TriggerObjects
226  TriggerObject theObj(p4(), pdgId());
227  // Set its collection and trigger objects types (no c'tor for that)
228  theObj.setCollection(collection());
229  for (size_t i = 0; i < triggerObjectTypes().size(); ++i)
230  theObj.addTriggerObjectType(triggerObjectTypes().at(i));
231  // Return TriggerObject
232  return theObj;
233 }
std::vector< int > triggerObjectTypes() const
Get all trigger object type identifiers.
const LorentzVector & p4() const final
four-momentum Lorentz vector
int pdgId() const final
PDG identifier.
const std::string & collection() const
Get the label of the collection the trigger object originates from.
Definition: TriggerObject.h:96

◆ unpackFilterLabels() [1/2]

void TriggerObjectStandAlone::unpackFilterLabels ( const std::vector< std::string > &  labels)

unpack filter labels from indices

Definition at line 364 of file TriggerObjectStandAlone.cc.

References Exception, filterLabelIndices_, filterLabels_, mps_fire::i, SummaryClient_cfi::labels, visualization-live-secondInstance_cfg::m, and dqmiodumpmetadata::n.

Referenced by unpackFilterLabels(), and unpackNamesAndLabels().

364  {
365  if (filterLabelIndices_.empty())
366  return;
367 
368  std::vector<std::string> mylabels(filterLabels_);
369  for (unsigned int i = 0, n = filterLabelIndices_.size(), m = labels.size(); i < n; ++i) {
370  if (filterLabelIndices_[i] >= m)
371  throw cms::Exception("RuntimeError", "Error, filter label index out of bounds");
372  mylabels.push_back(labels[filterLabelIndices_[i]]);
373  }
374  filterLabelIndices_.clear();
375  filterLabels_.swap(mylabels);
376 }
std::vector< uint16_t > filterLabelIndices_
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...

◆ unpackFilterLabels() [2/2]

void TriggerObjectStandAlone::unpackFilterLabels ( const edm::EventBase event,
const edm::TriggerResults res 
)

unpack filter labels from indices

Definition at line 360 of file TriggerObjectStandAlone.cc.

References allLabels(), psetId_, and unpackFilterLabels().

360  {
362 }
std::vector< std::string > const * allLabels(edm::ParameterSetID const &psetid, const edm::EventBase &event, const edm::TriggerResults &res) const
Definition: Electron.h:6
void unpackFilterLabels(const std::vector< std::string > &labels)
unpack filter labels from indices
Definition: event.py:1

◆ unpackNamesAndLabels()

void TriggerObjectStandAlone::unpackNamesAndLabels ( const edm::EventBase event,
const edm::TriggerResults res 
)

unpack both filter labels and trigger names

Definition at line 355 of file TriggerObjectStandAlone.cc.

References unpackFilterLabels(), and unpackPathNames().

355  {
356  unpackPathNames(event.triggerNames(res));
358 }
void unpackPathNames(const edm::TriggerNames &names)
unpack trigger names into indices
Definition: Electron.h:6
void unpackFilterLabels(const std::vector< std::string > &labels)
unpack filter labels from indices
Definition: event.py:1

◆ unpackPathNames()

void TriggerObjectStandAlone::unpackPathNames ( const edm::TriggerNames names)

unpack trigger names into indices

Definition at line 309 of file TriggerObjectStandAlone.cc.

References reco::Candidate::end(), Exception, mps_fire::i, dqmiodumpmetadata::n, names, pathIndices_, pathNames_, and Skims_PA_cff::paths.

Referenced by unpackNamesAndLabels().

309  {
310  if (!pathNames_.empty()) {
311  if (!pathIndices_.empty()) {
312  throw cms::Exception("RuntimeError", "Error, trying to unpack a partially unpacked TriggerObjectStandAlone");
313  } else {
314  return;
315  }
316  }
317  unsigned int n = pathIndices_.size(), end = names.size();
318  std::vector<std::string> paths(n);
319  for (unsigned int i = 0; i < n; ++i) {
320  if (pathIndices_[i] >= end)
321  throw cms::Exception("RuntimeError", "Error, path index out of bounds");
322  paths[i] = names.triggerName(pathIndices_[i]);
323  }
324  pathIndices_.clear();
325  pathNames_.swap(paths);
326 }
const std::string names[nVars_]
const_iterator end() const
last daughter const_iterator
Definition: Candidate.h:145
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
std::vector< uint16_t > pathIndices_

Member Data Documentation

◆ filterLabelIndices_

std::vector<uint16_t> pat::TriggerObjectStandAlone::filterLabelIndices_
private

◆ filterLabels_

std::vector<std::string> pat::TriggerObjectStandAlone::filterLabels_
private

Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in.

Data Members Keeping the old names of the data members for backward compatibility, although they refer only to HLT objects.

Definition at line 38 of file TriggerObjectStandAlone.h.

Referenced by addFilterOrCondition(), filtersOrConditions(), hasFilterOrCondition(), packFilterLabels(), TriggerObjectStandAlone(), and unpackFilterLabels().

◆ pathIndices_

std::vector<uint16_t> pat::TriggerObjectStandAlone::pathIndices_
private

◆ pathL3FilterAccepted_

std::vector<bool> pat::TriggerObjectStandAlone::pathL3FilterAccepted_
private

Vector alligned with 'pathNames_' of boolean indicating the usage of the trigger object An element is true, if the corresponding path succeeded and the trigger object was used in an L3 filter (HLT only) The vector is empty for data (size 0), if the according information is not available.

Definition at line 53 of file TriggerObjectStandAlone.h.

Referenced by addPathOrAlgorithm(), hasL3Filter(), hasPathOrAlgorithm(), pathsOrAlgorithms(), and TriggerObjectStandAlone().

◆ pathLastFilterAccepted_

std::vector<bool> pat::TriggerObjectStandAlone::pathLastFilterAccepted_
private

Vector alligned with 'pathNames_' of boolean indicating the usage of the trigger object An element is true, if the corresponding path succeeded and the trigger object was used in the last filter (HLT) or the corresponding algorithm succeeded as well as the corresponding condition (L1). The vector is empty for data (size 0), if the according information is not available.

Definition at line 49 of file TriggerObjectStandAlone.h.

Referenced by addPathOrAlgorithm(), hasLastFilter(), hasPathOrAlgorithm(), pathsOrAlgorithms(), and TriggerObjectStandAlone().

◆ pathNames_

std::vector<std::string> pat::TriggerObjectStandAlone::pathNames_
private

Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in.

Definition at line 42 of file TriggerObjectStandAlone.h.

Referenced by addPathOrAlgorithm(), checkIfPathsAreUnpacked(), hasL3Filter(), hasLastFilter(), hasPathOrAlgorithm(), packPathNames(), pathsOrAlgorithms(), TriggerObjectStandAlone(), and unpackPathNames().

◆ psetId_

edm::ParameterSetID pat::TriggerObjectStandAlone::psetId_
private

Definition at line 55 of file TriggerObjectStandAlone.h.

Referenced by packFilterLabels(), psetID(), setPSetID(), and unpackFilterLabels().

◆ wildcard_

const char TriggerObjectStandAlone::wildcard_ = '*'
staticprivate

Constants.

Constant defining the wild-card used in 'hasAnyName()'

Definition at line 60 of file TriggerObjectStandAlone.h.

Referenced by hasAnyName(), hasCollection(), hasFilterOrCondition(), and hasPathOrAlgorithm().