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)
 Methods. 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
 
virtual bool coll (const std::string &collName) const
 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...
 
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...
 
virtual bool hasCollection (const std::string &collName) const
 Checks, if a certain label of original collection is assigned (method overrides) More...
 
virtual bool hasCollection (const edm::InputTag &collName) const
 
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)
 
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...
 
virtual ~TriggerObjectStandAlone ()
 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
 
virtual ~TriggerObject ()
 Destructor. More...
 
- Public Member Functions inherited from reco::LeafCandidate
virtual Vector boostToCM () const final
 
virtual int charge () const final
 electric charge More...
 
virtual LeafCandidateclone () const
 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)
 
virtual const Candidatedaughter (size_type) const
 return daughter at a given position (throws an exception) More...
 
virtual Candidatedaughter (size_type)
 return daughter at a given position (throws an exception) More...
 
virtual Candidatedaughter (const std::string &s)
 return daughter with a specified role name More...
 
virtual const Candidatedaughter (const std::string &s) const
 return daughter with a specified role name More...
 
virtual double energy () const final
 energy More...
 
virtual double et () const final
 transverse energy More...
 
virtual double et2 () const final
 transverse energy squared (use this for cut!) More...
 
virtual double eta () const final
 momentum pseudorapidity More...
 
virtual void fillVertexCovariance (CovarianceMatrix &v) const
 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...
 
virtual bool hasMasterClone () const
 
virtual bool hasMasterClonePtr () const
 
virtual bool isCaloMuon () const
 
virtual bool isConvertedPhoton () const
 
virtual bool isElectron () const
 
virtual bool isGlobalMuon () const
 
virtual bool isJet () const
 
virtual bool isMuon () const
 
virtual bool isPhoton () const
 
virtual bool isStandAloneMuon () const
 
virtual bool isTrackerMuon () const
 
 LeafCandidate ()
 
 LeafCandidate (const Candidate &c)
 
template<typename... Args>
 LeafCandidate (Args &&...args)
 
 LeafCandidate (LeafCandidate &rh)
 
 LeafCandidate (LeafCandidate &&)=default
 
 LeafCandidate (LeafCandidate const &)=default
 
virtual bool longLived () const final
 is long lived? More...
 
virtual double mass () const final
 mass More...
 
virtual bool massConstraint () const final
 do mass constraint? More...
 
virtual double massSqr () const final
 mass squared More...
 
virtual const CandidateBaseRefmasterClone () const
 
virtual const CandidatePtrmasterClonePtr () const
 
template<typename Ref >
Ref masterRef () const
 cast master clone reference to a concrete type More...
 
virtual Vector momentum () const final
 spatial momentum vector More...
 
virtual const Candidatemother (size_type) const
 return mother at a given position (throws an exception) More...
 
virtual double mt () const final
 transverse mass More...
 
virtual 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...
 
virtual size_t numberOfDaughters () const
 number of daughters More...
 
virtual size_t numberOfMothers () const
 number of mothers More...
 
virtual size_t numberOfSourceCandidatePtrs () const
 
LeafCandidateoperator= (LeafCandidate &&)=default
 
LeafCandidateoperator= (LeafCandidate const &)=default
 
virtual double p () const final
 magnitude of momentum vector More...
 
virtual const LorentzVectorp4 () const final
 four-momentum Lorentz vector More...
 
virtual int pdgId () const final
 PDG identifier. More...
 
virtual double phi () const final
 momentum azimuthal angle More...
 
virtual const PolarLorentzVectorpolarP4 () const final
 four-momentum Lorentz vector More...
 
virtual double pt () const final
 transverse momentum More...
 
virtual double px () const final
 x coordinate of momentum vector More...
 
virtual double py () const final
 y coordinate of momentum vector More...
 
virtual double pz () const final
 z coordinate of momentum vector More...
 
virtual double rapidity () const final
 rapidity More...
 
virtual void setCharge (Charge q) final
 set electric charge More...
 
virtual void setLongLived () final
 
virtual void setMass (double m) final
 set particle mass More...
 
virtual void setMassConstraint () final
 
virtual void setP4 (const LorentzVector &p4) final
 set 4-momentum More...
 
virtual void setP4 (const PolarLorentzVector &p4) final
 set 4-momentum More...
 
virtual void setPdgId (int pdgId) final
 
virtual void setPz (double pz) final
 
virtual void setStatus (int status) final
 set status word More...
 
virtual void setThreeCharge (Charge qx3) final
 set electric charge More...
 
virtual void setVertex (const Point &vertex)
 set vertex More...
 
virtual CandidatePtr sourceCandidatePtr (size_type i) const
 
virtual int status () const final
 status word More...
 
virtual double theta () const final
 momentum polar angle More...
 
virtual int threeCharge () const final
 electric charge More...
 
virtual const Pointvertex () const
 vertex position (overwritten by PF...) More...
 
virtual double vertexChi2 () const
 chi-squares More...
 
virtual double vertexCovariance (int i, int j) const
 (i, j)-th element of error matrix, i, j = 0, ... 2 More...
 
CovarianceMatrix vertexCovariance () const final
 return SMatrix More...
 
virtual double vertexNdof () const
 
virtual double vertexNormalizedChi2 () const
 chi-squared divided by n.d.o.f. More...
 
virtual double vx () const
 x coordinate of vertex position More...
 
virtual double vy () const
 y coordinate of vertex position More...
 
virtual double vz () const
 z coordinate of vertex position More...
 
virtual double y () const final
 rapidity More...
 
virtual ~LeafCandidate ()
 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::TriggerObjectStandAlone ( )

Constructors and Destructor.

Default constructor

Definition at line 30 of file TriggerObjectStandAlone.cc.

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

30  :
32 {
33  filterLabels_.clear();
34  filterLabelIndices_.clear();
35  pathNames_.clear();
37  pathL3FilterAccepted_.clear();
38 }
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...
std::vector< bool > pathL3FilterAccepted_
TriggerObject()
Constructors and Destructor.
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
TriggerObjectStandAlone::TriggerObjectStandAlone ( const TriggerObject trigObj)

Constructor from pat::TriggerObject.

Definition at line 42 of file TriggerObjectStandAlone.cc.

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

42  :
43  TriggerObject( trigObj )
44 {
45  filterLabels_.clear();
46  filterLabelIndices_.clear();
47  pathNames_.clear();
49  pathL3FilterAccepted_.clear();
50 }
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...
std::vector< bool > pathL3FilterAccepted_
TriggerObject()
Constructors and Destructor.
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
TriggerObjectStandAlone::TriggerObjectStandAlone ( const trigger::TriggerObject trigObj)

Constructor from trigger::TriggerObject.

Definition at line 54 of file TriggerObjectStandAlone.cc.

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

54  :
55  TriggerObject( trigObj )
56 {
57  filterLabels_.clear();
58  filterLabelIndices_.clear();
59  pathNames_.clear();
61  pathL3FilterAccepted_.clear();
62 }
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...
std::vector< bool > pathL3FilterAccepted_
TriggerObject()
Constructors and Destructor.
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::LeafCandidate leafCand)

Constructor from reco::Candidate.

Definition at line 66 of file TriggerObjectStandAlone.cc.

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

66  :
67  TriggerObject( leafCand )
68 {
69  filterLabels_.clear();
70  filterLabelIndices_.clear();
71  pathNames_.clear();
73  pathL3FilterAccepted_.clear();
74 }
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...
std::vector< bool > pathL3FilterAccepted_
TriggerObject()
Constructors and Destructor.
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::Particle::LorentzVector vec,
int  id = 0 
)

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

Definition at line 78 of file TriggerObjectStandAlone.cc.

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

78  :
79  TriggerObject( vec, id )
80 {
81  filterLabels_.clear();
82  filterLabelIndices_.clear();
83  pathNames_.clear();
85  pathL3FilterAccepted_.clear();
86 }
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...
std::vector< bool > pathL3FilterAccepted_
TriggerObject()
Constructors and Destructor.
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::Particle::PolarLorentzVector vec,
int  id = 0 
)

Definition at line 87 of file TriggerObjectStandAlone.cc.

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

87  :
88  TriggerObject( vec, id )
89 {
90  filterLabels_.clear();
91  filterLabelIndices_.clear();
92  pathNames_.clear();
94  pathL3FilterAccepted_.clear();
95 }
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...
std::vector< bool > pathL3FilterAccepted_
TriggerObject()
Constructors and Destructor.
std::vector< uint16_t > filterLabelIndices_
std::vector< bool > pathLastFilterAccepted_
virtual pat::TriggerObjectStandAlone::~TriggerObjectStandAlone ( )
inlinevirtual

Destructor.

Definition at line 105 of file TriggerObjectStandAlone.h.

105 {};

Member Function Documentation

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

Adds a new L1 algorithm name.

Definition at line 116 of file TriggerObjectStandAlone.h.

116 { addPathOrAlgorithm( algorithmName, algoCondAccepted, false ); };
void addPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted)
Adds a new HLT path or L1 algorithm name.
void pat::TriggerObjectStandAlone::addConditionName ( const std::string &  conditionName)
inline

Adds a new L1 condition name.

Definition at line 112 of file TriggerObjectStandAlone.h.

112 { addFilterOrCondition( conditionName ); };
void addFilterOrCondition(const std::string &name)
Adds a new HLT filter label or L1 condition name.
void pat::TriggerObjectStandAlone::addFilterLabel ( const std::string &  filterLabel)
inline

Methods.

Adds a new HLT filter label

Definition at line 110 of file TriggerObjectStandAlone.h.

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

110 { addFilterOrCondition( filterLabel ); };
void addFilterOrCondition(const std::string &name)
Adds a new HLT filter label or L1 condition name.
void pat::TriggerObjectStandAlone::addFilterOrCondition ( const std::string &  name)
inlineprivate

Adds a new HLT filter label or L1 condition name.

Definition at line 68 of file TriggerObjectStandAlone.h.

References dataset::name, and AlCaHLTBitMon_QueryRunRegistry::string.

68 { if ( ! hasFilterOrCondition( name ) ) filterLabels_.push_back( name ); };
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.
void pat::TriggerObjectStandAlone::addPathName ( const std::string &  pathName,
bool  pathLastFilterAccepted = true,
bool  pathL3FilterAccepted = true 
)
inline

Adds a new HLT path name.

Definition at line 114 of file TriggerObjectStandAlone.h.

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

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

Adds a new HLT path or L1 algorithm name.

Definition at line 148 of file TriggerObjectStandAlone.cc.

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

149 {
151 
152  // Check, if path is already assigned
153  if ( ! hasPathOrAlgorithm( name, false, false ) ) {
154  // The path itself
155  pathNames_.push_back( name );
156  // The corresponding usage of the trigger objects
157  pathLastFilterAccepted_.push_back( pathLastFilterAccepted );
158  pathL3FilterAccepted_.push_back( pathL3FilterAccepted );
159  // Enable status updates
160  } else if ( pathLastFilterAccepted || pathL3FilterAccepted ) {
161  // Search for path
162  unsigned index( 0 );
163  while ( index < pathNames_.size() ) {
164  if ( pathNames_.at( index ) == name ) break;
165  ++index;
166  }
167  // Status update
168  if ( index < pathNames_.size() ) {
169  pathLastFilterAccepted_.at( index ) = pathLastFilterAccepted_.at( index ) || pathLastFilterAccepted;
170  pathL3FilterAccepted_.at( index ) = pathL3FilterAccepted_.at( index ) || pathL3FilterAccepted;
171  }
172  }
173 }
bool checkIfPathsAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packPathNames() and not yet unpacked.
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
unsigned int index
Definition: LeafCandidate.h:31
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_
std::vector< bool > pathLastFilterAccepted_
bool pat::TriggerObjectStandAlone::algo ( const std::string &  algorithmName,
unsigned  algoCondAccepted = 1 
) const
inline

Calls 'hasAlgorithmName(...)'.

Definition at line 154 of file TriggerObjectStandAlone.h.

154 { return hasAlgorithmName( algorithmName, bool( algoCondAccepted ) ); };
bool hasAlgorithmName(const std::string &algorithmName, bool algoCondAccepted=true) const
Checks, if a certain L1 algorithm name is assigned.
std::vector< std::string > pat::TriggerObjectStandAlone::algorithmNames ( bool  algoCondAccepted = true) const
inline

Gets all L1 algorithm names.

Definition at line 124 of file TriggerObjectStandAlone.h.

124 { return pathsOrAlgorithms( algoCondAccepted, false ); };
std::vector< std::string > pathsOrAlgorithms(bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Gets all HLT path or L1 algorithm names.
std::vector< std::string > const * TriggerObjectStandAlone::allLabels ( edm::ParameterSetID const &  psetid,
const edm::EventBase event,
const edm::TriggerResults res 
) const

Definition at line 399 of file TriggerObjectStandAlone.cc.

References edm::ParameterSet::exists(), edm::ParameterSet::existsAs(), edm::pset::Registry::getMapped(), edm::ParameterSet::getParameter(), edm::ParameterSet::getParameterSet(), mps_fire::i, edm::ParameterSet::insert(), edm::pset::Registry::instance(), funct::m, gen::n, and muonDTDigis_cfi::pset.

Referenced by packFilterLabels(), and unpackFilterLabels().

399  {
400 
401  // If TriggerNames was already created and cached here in the map,
402  // then look it up and return that one
403  AllLabelsMap::const_iterator iter =
404  allLabelsMap.find(psetid);
405  if (iter != allLabelsMap.end()) {
406  return &iter->second;
407  }
408 
409  auto triggerNames= event.triggerNames(res); //this also ensure that the registry is filled
411  edm::ParameterSet const* pset=0;
412  if (0!=(pset=psetRegistry->getMapped(psetid ))) {
413  using namespace std;
414  using namespace edm;
415  using namespace trigger;
416 
417 
418  const unsigned int n(triggerNames.size());
419  std::set<std::string> saveTags;
420  for (unsigned int i=0;i!=n; ++i) {
421  if (pset->existsAs<vector<string> >(triggerNames.triggerName(i),true)) {
422  auto modules = pset->getParameter<vector<string> >(triggerNames.triggerName(i));
423  for(size_t m=0; m < modules.size(); m++){
424  auto module=modules[m];
425  auto moduleStrip=module.front()!='-' ? module : module.substr(1);
426 
427  if (pset->exists(moduleStrip)) {
428  auto modulePSet= pset->getParameterSet(moduleStrip);
429  if (modulePSet.existsAs<bool>("saveTags",true) and
430  modulePSet.getParameter<bool>("saveTags") ) {
431  saveTags.insert(moduleStrip);
432  }
433  }
434  }
435  }
436  }
437  std::vector<std::string> allModules(saveTags.begin(),saveTags.end());
438  std::pair<AllLabelsMap::iterator, bool> ret =
439  allLabelsMap.insert(std::pair<edm::ParameterSetID, std::vector<std::string> >(psetid, allModules));
440  return &(ret.first->second);
441  }
442  return 0;
443  }
T getParameter(std::string const &) const
bool existsAs(std::string const &parameterName, bool trackiness=true) const
checks if a parameter exists as a given type
Definition: ParameterSet.h:186
bool exists(std::string const &parameterName) const
checks if a parameter exists
void insert(bool ok_to_replace, char const *, Entry const &)
bool getMapped(key_type const &k, value_type &result) const
Definition: Registry.cc:18
ParameterSet const & getParameterSet(std::string const &) const
HLT enums.
Definition: vlib.h:208
static Registry * instance()
Definition: Registry.cc:12
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 277 of file TriggerObjectStandAlone.cc.

References Exception, and filterLabelIndices_.

Referenced by hasFilterOrCondition().

277  {
278  bool unpacked = filterLabelIndices_.empty();
279  if (!unpacked && throwIfPacked) throw cms::Exception("RuntimeError", "This TriggerObjectStandAlone object has packed trigger filter labels. Before accessing path names you must call unpackFilterLabels with an edm::EventBase object. Both the edm::Event or fwlite::Event are derived from edm::EventBase and can be passed\n");
280  return unpacked;
281 }
std::vector< uint16_t > filterLabelIndices_
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 272 of file TriggerObjectStandAlone.cc.

References Exception, pathIndices_, and pathNames_.

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

272  {
273  bool unpacked = (!pathNames_.empty() || pathIndices_.empty());
274  if (!unpacked && throwIfPacked) throw cms::Exception("RuntimeError", "This TriggerObjectStandAlone object has packed trigger path names. Before accessing path names you must call unpackPathNames with an edm::TriggerNames object. You can get the latter from the edm::Event or fwlite::Event and the TriggerResults\n");
275  return unpacked;
276 }
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_
virtual bool pat::TriggerObjectStandAlone::coll ( const std::string &  collName) const
inlinevirtual

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

Reimplemented from pat::TriggerObject.

Definition at line 156 of file TriggerObjectStandAlone.h.

156 { return hasCollection( collName ); };
virtual bool hasCollection(const std::string &collName) const
Checks, if a certain label of original collection is assigned (method overrides)
bool pat::TriggerObjectStandAlone::cond ( const std::string &  conditionName) const
inline

Calls 'hasConditionName(...)'.

Definition at line 150 of file TriggerObjectStandAlone.h.

150 { return hasConditionName( conditionName ); };
bool hasConditionName(const std::string &conditionName) const
Checks, if a certain L1 condition name is assigned.
const std::vector< std::string >& pat::TriggerObjectStandAlone::conditionNames ( ) const
inline

Gets all L1 condition names.

Definition at line 120 of file TriggerObjectStandAlone.h.

120 { return filtersOrConditions(); };
const std::vector< std::string > & filtersOrConditions() const
Gets all HLT filter labels or L1 condition names.
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 148 of file TriggerObjectStandAlone.h.

Referenced by Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::filter(), Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::find(), Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::setDataAccessor(), and Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::switchCenterView().

148 { return hasFilterLabel( filterLabel ); };
bool hasFilterLabel(const std::string &filterLabel) const
Checks, if a certain HLT filter label is assigned.
const std::vector< std::string >& pat::TriggerObjectStandAlone::filterLabels ( ) const
inline

Gets all HLT filter labels.

Definition at line 118 of file TriggerObjectStandAlone.h.

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

Gets all HLT filter labels or L1 condition names.

Definition at line 72 of file TriggerObjectStandAlone.h.

References AlCaHLTBitMon_QueryRunRegistry::string.

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...
bool pat::TriggerObjectStandAlone::hasAlgoCondAccepted ( ) const
inline

Definition at line 140 of file TriggerObjectStandAlone.h.

140 { return hasLastFilter(); };
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.
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 134 of file TriggerObjectStandAlone.h.

References AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by pat::PATObject< ObjectType >::triggerObjectMatchByAlgorithm(), and pat::PATObject< ObjectType >::triggerObjectMatchesByAlgorithm().

134 { return hasPathOrAlgorithm( algorithmName, algoCondAccepted, false ); };
bool hasPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Checks, if a certain HLT path or L1 algorithm name is assigned.
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 102 of file TriggerObjectStandAlone.cc.

References runEdmFileComparison::failed, split, AlCaHLTBitMon_QueryRunRegistry::string, and wildcard_.

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

103 {
104  // Special cases first
105  // Always false for empty vector to check
106  if ( nameVec.empty() ) return false;
107  // Always true for general wild-card(s)
108  if ( name.find_first_not_of( wildcard_ ) == std::string::npos ) return true;
109  // Split name to evaluate in parts, seperated by wild-cards
110  std::vector< std::string > namePartsVec;
111  boost::split( namePartsVec, name, boost::is_any_of( std::string( 1, wildcard_ ) ), boost::token_compress_on );
112  // Iterate over vector of names to search
113  for ( std::vector< std::string >::const_iterator iVec = nameVec.begin(); iVec != nameVec.end(); ++iVec ) {
114  // Not failed yet
115  bool failed( false );
116  // Start searching at the first character
117  size_type index( 0 );
118  // Iterate over evaluation name parts
119  for ( std::vector< std::string >::const_iterator iName = namePartsVec.begin(); iName != namePartsVec.end(); ++iName ) {
120  // Empty parts due to
121  // - wild-card at beginning/end or
122  // - multiple wild-cards (should be supressed by 'boost::token_compress_on')
123  if ( iName->length() == 0 ) continue;
124  // Search from current index and
125  // set index to found occurence
126  index = iVec->find( *iName, index );
127  // Failed and exit loop, if
128  // - part not found
129  // - part at beginning not found there
130  if ( index == std::string::npos || ( iName == namePartsVec.begin() && index > 0 ) ) {
131  failed = true;
132  break;
133  }
134  // Increase index by length of found part
135  index += iName->length();
136  }
137  // Failed, if end of name not reached
138  if ( index < iVec->length() && namePartsVec.back().length() != 0 ) failed = true;
139  // Match found!
140  if ( ! failed ) return true;
141  }
142  // No match found!
143  return false;
144 }
static const char wildcard_
Constants.
uint16_t size_type
unsigned int index
Definition: LeafCandidate.h:31
double split
Definition: MVATrainer.cc:139
bool TriggerObjectStandAlone::hasCollection ( const std::string &  collName) const
virtual

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

Reimplemented from pat::TriggerObject.

Definition at line 248 of file TriggerObjectStandAlone.cc.

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

Referenced by pat::PATTriggerProducer::produce(), pat::PATObject< ObjectType >::triggerObjectMatchByCollection(), and pat::PATObject< ObjectType >::triggerObjectMatchesByCollection().

249 {
250  // Move to wild-card parser, if needed only
251  if ( collName.find( wildcard_ ) != std::string::npos ) {
252  // True, if collection name is simply fine
253  if ( hasAnyName( collName, std::vector< std::string >( 1, collection() ) ) ) return true;
254  // Check, if collection name possibly fits in an edm::InputTag approach
255  const edm::InputTag collectionTag( collection() );
256  const edm::InputTag collTag( collName );
257  // If evaluated collection tag contains a process name, it must have been found already by identity check
258  if ( collTag.process().empty() ) {
259  // Check instance ...
260  if ( ( collTag.instance().empty() && collectionTag.instance().empty() ) || hasAnyName( collTag.instance(), std::vector< std::string >( 1, collectionTag.instance() ) ) ) {
261  // ... and label
262  return hasAnyName( collTag.label(), std::vector< std::string >( 1, collectionTag.label() ) );
263  }
264  }
265  return false;
266  }
267  // Use parent class's method otherwise
268  return TriggerObject::hasCollection( collName );
269 }
static const char wildcard_
Constants.
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:92
virtual bool hasCollection(const std::string &collName) const
Checks, if a certain label of original collection is assigned.
virtual bool pat::TriggerObjectStandAlone::hasCollection ( const edm::InputTag collName) const
inlinevirtual

Reimplemented from pat::TriggerObject.

Definition at line 137 of file TriggerObjectStandAlone.h.

References edm::InputTag::encode(), and hasCollection().

Referenced by hasCollection().

137 { return hasCollection( collName.encode() ); };
virtual bool hasCollection(const std::string &collName) const
Checks, if a certain label of original collection is assigned (method overrides)
std::string encode() const
Definition: InputTag.cc:166
bool pat::TriggerObjectStandAlone::hasConditionName ( const std::string &  conditionName) const
inline

Checks, if a certain L1 condition name is assigned.

Definition at line 130 of file TriggerObjectStandAlone.h.

Referenced by pat::PATObject< ObjectType >::triggerObjectMatchByCondition(), and pat::PATObject< ObjectType >::triggerObjectMatchesByCondition().

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

Checks, if a certain HLT filter label is assigned.

Definition at line 128 of file TriggerObjectStandAlone.h.

Referenced by pat::PATObject< ObjectType >::triggerObjectMatchByFilter(), and pat::PATObject< ObjectType >::triggerObjectMatchesByFilter().

128 { return hasFilterOrCondition( filterLabel ); };
bool hasFilterOrCondition(const std::string &name) const
Checks, if a certain HLT filter label or L1 condition name is assigned.
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 198 of file TriggerObjectStandAlone.cc.

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

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

Definition at line 81 of file TriggerObjectStandAlone.h.

Referenced by hasPathOrAlgorithm(), and pathsOrAlgorithms().

81 { return ( pathL3FilterAccepted_.size() > 0 && pathL3FilterAccepted_.size() == pathNames_.size() ); };
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_
bool pat::TriggerObjectStandAlone::hasLastFilter ( ) const
inlineprivate

Check, if the usage indicator vectors have been filled.

Definition at line 80 of file TriggerObjectStandAlone.h.

Referenced by hasPathOrAlgorithm(), and pathsOrAlgorithms().

80 { return ( pathLastFilterAccepted_.size() > 0 && pathLastFilterAccepted_.size() == pathNames_.size() ); };
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 > pathLastFilterAccepted_
bool pat::TriggerObjectStandAlone::hasPathL3FilterAccepted ( ) const
inline

Definition at line 141 of file TriggerObjectStandAlone.h.

141 { return hasL3Filter(); };
bool pat::TriggerObjectStandAlone::hasPathLastFilterAccepted ( ) const
inline

Checks, if the usage indicator vector has been filled.

Definition at line 139 of file TriggerObjectStandAlone.h.

139 { return hasLastFilter(); };
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.
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 132 of file TriggerObjectStandAlone.h.

Referenced by pat::PATObject< ObjectType >::triggerObjectMatchByPath(), and pat::PATObject< ObjectType >::triggerObjectMatchesByPath().

132 { return hasPathOrAlgorithm( pathName, pathLastFilterAccepted, pathL3FilterAccepted ); };
bool hasPathOrAlgorithm(const std::string &name, bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Checks, if a certain HLT path or L1 algorithm name is assigned.
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 210 of file TriggerObjectStandAlone.cc.

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

Referenced by addPathOrAlgorithm().

211 {
213 
214  // Move to wild-card parser, if needed
215  if ( name.find( wildcard_ ) != std::string::npos ) return hasAnyName( name, pathsOrAlgorithms( pathLastFilterAccepted, pathL3FilterAccepted ) );
216  // Deal with older PAT-tuples, where trigger object usage is not available
217  if ( ! hasLastFilter() ) pathLastFilterAccepted = false;
218  if ( ! hasL3Filter() ) pathL3FilterAccepted = false;
219  // Check, if path name is assigned at all
220  std::vector< std::string >::const_iterator match( std::find( pathNames_.begin(), pathNames_.end(), name ) );
221  // False, if path name not assigned
222  if ( match == pathNames_.end() ) return false;
223  if ( ! pathLastFilterAccepted && ! pathL3FilterAccepted ) return true;
224  bool foundLastFilter( pathLastFilterAccepted ? pathLastFilterAccepted_.at( match - pathNames_.begin() ) : true );
225  bool foundL3Filter( pathL3FilterAccepted ? pathL3FilterAccepted_.at( match - pathNames_.begin() ) : true );
226  // Return for assigned path name, if trigger object usage meets requirement
227  return ( foundLastFilter && foundL3Filter );
228 }
std::vector< std::string > pathsOrAlgorithms(bool pathLastFilterAccepted, bool pathL3FilterAccepted) const
Gets all HLT path or L1 algorithm names.
bool checkIfPathsAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packPathNames() and not yet unpacked.
static const char wildcard_
Constants.
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:20
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.
std::vector< bool > pathL3FilterAccepted_
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:10
std::vector< bool > pathLastFilterAccepted_
void TriggerObjectStandAlone::packFilterLabels ( const edm::EventBase event,
const edm::TriggerResults res 
)

Definition at line 376 of file TriggerObjectStandAlone.cc.

References allLabels(), and psetId_.

376  {
377  packFilterLabels(*allLabels(psetId_,event,res));
378 }
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
void TriggerObjectStandAlone::packFilterLabels ( const std::vector< std::string > &  labels)

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

Definition at line 330 of file TriggerObjectStandAlone.cc.

References Exception, filterLabelIndices_, filterLabels_, mps_fire::i, match(), eostools::move(), and gen::n.

330  {
331  if (!filterLabelIndices_.empty()) {
332  throw cms::Exception("RuntimeError", "Error, trying to pack filter labels for an already packed TriggerObjectStandAlone");
333  }
334  std::vector<std::string> unmatched;
335  std::vector<uint16_t> indices;
336  indices.reserve(filterLabels_.size());
337 
338  auto nStart = names.begin(), nEnd = names.end();
339  for (unsigned int i = 0, n = filterLabels_.size(); i < n; ++i) {
340  auto match = std::lower_bound(nStart, nEnd, filterLabels_[i]);
341  if (match != nEnd && *match == filterLabels_[i]) {
342  indices.push_back(match - nStart);
343  } else {
344  static std::atomic<int> _warn(0);
345  if(++_warn < 5) edm::LogWarning("TriggerObjectStandAlone::packFilterLabels()") << "Warning: can't resolve '" << filterLabels_[i] << "' to a label index. idx: " << i <<std::endl;
346  unmatched.push_back(std::move(filterLabels_[i]));
347  }
348  }
349  std::sort(indices.begin(), indices.end()); // try reduce enthropy
350  filterLabelIndices_.swap(indices);
351  filterLabels_.swap(unmatched);
352 }
static const HistoName names[]
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
std::vector< uint16_t > filterLabelIndices_
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:10
def move(src, dest)
Definition: eostools.py:510
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(), reco::LeafCandidate::setP4(), and edm::Hash< I >::smallHash().

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

pack trigger names into indices

Definition at line 285 of file TriggerObjectStandAlone.cc.

References reco::Candidate::end(), Exception, mps_fire::i, pat::TriggerObject::id(), gen::n, convertSQLiteXML::ok, pathIndices_, pathNames_, edm::TriggerNames::size(), and edm::TriggerNames::triggerIndex().

285  {
286  if (!pathIndices_.empty()) {
287  if (!pathNames_.empty()) {
288  throw cms::Exception("RuntimeError", "Error, trying to pack a partially packed TriggerObjectStandAlone");
289  } else {
290  return;
291  }
292  }
293  bool ok = true;
294  unsigned int n = pathNames_.size(), end = names.size();
295  std::vector<uint16_t> indices(n);
296  for (unsigned int i = 0; i < n; ++i) {
297  uint16_t id = names.triggerIndex(pathNames_[i]);
298  if (id >= end) {
299  static std::atomic<int> _warn(0);
300  if (++_warn < 5) edm::LogWarning("TriggerObjectStandAlone::packPathNames()") << "Warning: can't resolve '" << pathNames_[i] << "' to a path index" << std::endl;
301  ok = false; break;
302  } else {
303  indices[i] = id;
304  }
305  }
306  if (ok) {
307  pathIndices_.swap(indices);
308  pathNames_.clear();
309  }
310 }
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...
Strings::size_type size() const
Definition: TriggerNames.cc:39
unsigned int triggerIndex(std::string const &name) const
Definition: TriggerNames.cc:32
const_iterator end() const
last daughter const_iterator
Definition: Candidate.h:146
std::vector< uint16_t > pathIndices_
bool pat::TriggerObjectStandAlone::path ( const std::string &  pathName,
unsigned  pathLastFilterAccepted = 0,
unsigned  pathL3FilterAccepted = 1 
) const
inline

Calls 'hasPathName(...)'.

Definition at line 152 of file TriggerObjectStandAlone.h.

152 { return hasPathName( pathName, bool( pathLastFilterAccepted ), bool( pathL3FilterAccepted ) ); };
bool hasPathName(const std::string &pathName, bool pathLastFilterAccepted=false, bool pathL3FilterAccepted=true) const
Checks, if a certain HLT path name is assigned.
std::vector< std::string > pat::TriggerObjectStandAlone::pathNames ( bool  pathLastFilterAccepted = false,
bool  pathL3FilterAccepted = true 
) const
inline

Gets all HLT path names.

Definition at line 122 of file TriggerObjectStandAlone.h.

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

Gets all HLT path or L1 algorithm names.

Definition at line 177 of file TriggerObjectStandAlone.cc.

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

Referenced by hasPathOrAlgorithm().

178 {
180 
181  // Deal with older PAT-tuples, where trigger object usage is not available
182  if ( ! hasLastFilter() ) pathLastFilterAccepted = false;
183  if ( ! hasL3Filter() ) pathL3FilterAccepted = false;
184  // All path names, if usage not restricted (not required or not available)
185  if ( ! pathLastFilterAccepted && ! pathL3FilterAccepted ) return pathNames_;
186  // Temp vector of path names
187  std::vector< std::string > paths;
188  // Loop over usage vector and fill corresponding paths into temp vector
189  for ( unsigned iPath = 0; iPath < pathNames_.size(); ++iPath ) {
190  if ( ( ! pathLastFilterAccepted || pathLastFilterAccepted_.at( iPath ) ) && ( ! pathL3FilterAccepted || pathL3FilterAccepted_.at( iPath ) ) ) paths.push_back( pathNames_.at( iPath ) ); // order matters in order to protect from empty vectors in old data
191  }
192  // Return temp vector
193  return paths;
194 }
bool checkIfPathsAreUnpacked(bool throwIfPacked=true) const
Check if trigger names have been packed by calling packPathNames() and not yet unpacked.
std::vector< std::string > pathNames_
Vector of names of all HLT paths or L1 algorithms the trigger objects has been used in...
bool hasLastFilter() const
Check, if the usage indicator vectors have been filled.
std::vector< bool > pathL3FilterAccepted_
std::vector< bool > pathLastFilterAccepted_
const edm::ParameterSetID& pat::TriggerObjectStandAlone::psetID ( ) const
inline
void pat::TriggerObjectStandAlone::setPSetID ( const edm::ParameterSetID psetId)
inline

set the psetid of the trigger process

Definition at line 159 of file TriggerObjectStandAlone.h.

159 {psetId_=psetId;}
TriggerObject TriggerObjectStandAlone::triggerObject ( )

Gets the pat::TriggerObject (parent class)

Definition at line 235 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().

236 {
237  // Create a TriggerObjects
238  TriggerObject theObj( p4(), pdgId() );
239  // Set its collection and trigger objects types (no c'tor for that)
240  theObj.setCollection( collection() );
241  for ( size_t i = 0; i < triggerObjectTypes().size(); ++i ) theObj.addTriggerObjectType( triggerObjectTypes().at( i ) );
242  // Return TriggerObject
243  return theObj;
244 }
const std::string & collection() const
Get the label of the collection the trigger object originates from.
Definition: TriggerObject.h:92
virtual int pdgId() const final
PDG identifier.
std::vector< int > triggerObjectTypes() const
Get all trigger object type identifiers.
virtual const LorentzVector & p4() const final
four-momentum Lorentz vector
Definition: LeafCandidate.h:99
void TriggerObjectStandAlone::unpackFilterLabels ( const std::vector< std::string > &  labels)

unpack filter labels from indices

Definition at line 365 of file TriggerObjectStandAlone.cc.

References Exception, filterLabelIndices_, filterLabels_, mps_fire::i, funct::m, and gen::n.

Referenced by unpackFilterLabels(), and unpackNamesAndLabels().

365  {
366  if (filterLabelIndices_.empty()) 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) throw cms::Exception("RuntimeError", "Error, filter label index out of bounds");
371  mylabels.push_back(labels[filterLabelIndices_[i]]);
372  }
373  filterLabelIndices_.clear();
374  filterLabels_.swap(mylabels);
375 }
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names of L1 conditions the trigger objects has been used in...
std::vector< uint16_t > filterLabelIndices_
void TriggerObjectStandAlone::unpackFilterLabels ( const edm::EventBase event,
const edm::TriggerResults res 
)

unpack filter labels from indices

Definition at line 361 of file TriggerObjectStandAlone.cc.

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

361  {
362  unpackFilterLabels(*allLabels(psetId_,event,res));
363 }
std::vector< std::string > const * allLabels(edm::ParameterSetID const &psetid, const edm::EventBase &event, const edm::TriggerResults &res) const
void unpackFilterLabels(const std::vector< std::string > &labels)
unpack filter labels from indices
void TriggerObjectStandAlone::unpackNamesAndLabels ( const edm::EventBase event,
const edm::TriggerResults res 
)

unpack both filter labels and trigger names

Definition at line 354 of file TriggerObjectStandAlone.cc.

References edm::EventBase::triggerNames(), unpackFilterLabels(), and unpackPathNames().

355 {
356  unpackPathNames(event.triggerNames(res));
357  unpackFilterLabels(event,res);
358 
359 }
void unpackPathNames(const edm::TriggerNames &names)
unpack trigger names into indices
void unpackFilterLabels(const std::vector< std::string > &labels)
unpack filter labels from indices
virtual TriggerNames const & triggerNames(edm::TriggerResults const &triggerResults) const =0
void TriggerObjectStandAlone::unpackPathNames ( const edm::TriggerNames names)

unpack trigger names into indices

Definition at line 312 of file TriggerObjectStandAlone.cc.

References reco::Candidate::end(), Exception, mps_fire::i, gen::n, pathIndices_, pathNames_, edm::TriggerNames::size(), and edm::TriggerNames::triggerName().

Referenced by unpackNamesAndLabels().

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

Member Data Documentation

std::vector< uint16_t > pat::TriggerObjectStandAlone::filterLabelIndices_
private
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 39 of file TriggerObjectStandAlone.h.

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

std::vector< uint16_t > pat::TriggerObjectStandAlone::pathIndices_
private
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 54 of file TriggerObjectStandAlone.h.

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

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 50 of file TriggerObjectStandAlone.h.

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

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 43 of file TriggerObjectStandAlone.h.

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

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

Definition at line 56 of file TriggerObjectStandAlone.h.

Referenced by packFilterLabels(), and unpackFilterLabels().

const char TriggerObjectStandAlone::wildcard_ = '*'
staticprivate

Constants.

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

Definition at line 61 of file TriggerObjectStandAlone.h.

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