CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
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)
 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...
 
virtual bool coll (const std::string &collName) const
 Calls 'hasCollection(...)' (method override) More...
 
bool cond (const std::string &conditionName) const
 Calls 'hasConditionName(...)'. More...
 
std::vector< std::string > conditionNames () const
 Gets all L1 condition names. More...
 
bool filter (const std::string &filterLabel) const
 Calls 'hasFilterLabel(...)'. More...
 
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 hasPathLastFilterAccepted () const
 Checks, if the usage indicator vector has been filled. More...
 
bool hasPathName (const std::string &pathName, bool pathLastFilterAccepted=true) const
 Checks, if a certain HLT path name is assigned. More...
 
bool path (const std::string &pathName, unsigned pathLastFilterAccepted=1) const
 Calls 'hasPathName(...)'. More...
 
std::vector< std::string > pathNames (bool pathLastFilterAccepted=true) const
 Gets all HLT path names. 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)
 
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)
 
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 const_iterator begin () const
 first daughter const_iterator More...
 
virtual iterator begin ()
 first daughter iterator More...
 
template<typename S >
daughter_iterator< S >::type beginFilter (const S &s) const
 
virtual Vector boostToCM () const
 
virtual int charge () const
 electric charge More...
 
virtual LeafCandidateclone () const
 returns a clone of the Candidate object More...
 
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 const_iterator end () const
 last daughter const_iterator More...
 
virtual iterator end ()
 last daughter iterator More...
 
template<typename S >
daughter_iterator< S >::type endFilter (const S &s) const
 
virtual double energy () const
 energy More...
 
virtual double et () const
 transverse energy More...
 
virtual double eta () const
 momentum pseudorapidity More...
 
virtual void fillVertexCovariance (CovarianceMatrix &v) const
 fill SMatrix More...
 
template<typename T >
get () const
 get a component More...
 
template<typename T , typename Tag >
get () const
 get a component More...
 
template<typename T >
get (size_type i) const
 get a component More...
 
template<typename T , typename Tag >
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 ()
 default constructor More...
 
 LeafCandidate (const Candidate &c)
 
 LeafCandidate (Charge q, const LorentzVector &p4, const Point &vtx=Point(0, 0, 0), int pdgId=0, int status=0, bool integerCharge=true)
 constructor from values More...
 
 LeafCandidate (Charge q, const PolarLorentzVector &p4, const Point &vtx=Point(0, 0, 0), int pdgId=0, int status=0, bool integerCharge=true)
 constructor from values More...
 
virtual bool longLived () const
 is long lived? More...
 
virtual double mass () const
 mass More...
 
virtual bool massConstraint () const
 do mass constraint? More...
 
virtual double massSqr () const
 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
 spatial momentum vector More...
 
virtual const Candidatemother (size_type) const
 return mother at a given position (throws an exception) More...
 
virtual double mt () const
 transverse mass More...
 
virtual double mtSqr () const
 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
 
virtual double p () const
 magnitude of momentum vector More...
 
virtual const LorentzVectorp4 () const
 four-momentum Lorentz vector More...
 
virtual int pdgId () const
 PDG identifier. More...
 
virtual double phi () const
 momentum azimuthal angle More...
 
virtual const PolarLorentzVectorpolarP4 () const
 four-momentum Lorentz vector More...
 
virtual double pt () const
 transverse momentum More...
 
virtual double px () const
 x coordinate of momentum vector More...
 
virtual double py () const
 y coordinate of momentum vector More...
 
virtual double pz () const
 z coordinate of momentum vector More...
 
virtual double rapidity () const
 rapidity More...
 
virtual void setCharge (Charge q)
 set electric charge More...
 
virtual void setLongLived ()
 set long lived flag More...
 
virtual void setMass (double m)
 set particle mass More...
 
virtual void setMassConstraint ()
 set mass constraint flag More...
 
virtual void setP4 (const LorentzVector &p4)
 set 4-momentum More...
 
virtual void setP4 (const PolarLorentzVector &p4)
 set 4-momentum More...
 
virtual void setPdgId (int pdgId)
 
virtual void setPz (double pz)
 
virtual void setStatus (int status)
 set status word More...
 
virtual void setThreeCharge (Charge qx3)
 set electric charge More...
 
virtual void setVertex (const Point &vertex)
 set vertex More...
 
virtual CandidatePtr sourceCandidatePtr (size_type i) const
 
virtual int status () const
 status word More...
 
virtual double theta () const
 momentum polar angle More...
 
virtual int threeCharge () const
 electric charge More...
 
virtual const Pointvertex () const
 vertex position 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
 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
 rapidity More...
 
virtual ~LeafCandidate ()
 destructor More...
 
- Public Member Functions inherited from reco::Candidate
template<typename S >
daughter_iterator< S >::type beginFilter (const S &s) const
 
 Candidate ()
 default constructor More...
 
template<typename S >
daughter_iterator< S >::type endFilter (const S &s) const
 
template<typename T >
get () const
 get a component More...
 
template<typename T , typename Tag >
get () const
 get a component More...
 
template<typename T >
get (size_type i) const
 get a component More...
 
template<typename T , typename Tag >
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 firing=true)
 Adds a new HLT path or L1 algorithm name. More...
 
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 hasFiring () const
 Checks, if the usage indicator vector has been filled. More...
 
bool hasPathOrAlgorithm (const std::string &name, bool firing=true) const
 Checks, if a certain HLT path or L1 algorithm name is assigned. More...
 
std::vector< std::string > pathsOrAlgorithms (bool firing=true) const
 Gets all HLT path or L1 algorithm names. More...
 

Private Attributes

std::vector< std::string > filterLabels_
 Vector of labels of all HLT filters or names od L1 conditions the trigger objects has been used in. More...
 
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...
 

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...
 
- Static Public Attributes inherited from reco::LeafCandidate
static const unsigned int longLivedTag = 65536
 long lived flag More...
 
static const unsigned int massConstraintTag = 131072
 do mass constraint flag More...
 
- Protected Member Functions inherited from reco::LeafCandidate
void cacheCartesian () const
 set internal cache More...
 
void cachePolar () const
 set internal cache More...
 
void clearCache () const
 clear internal cache More...
 
virtual bool overlap (const Candidate &) const
 check overlap with another Candidate More...
 
- Protected Attributes inherited from reco::LeafCandidate
edm::BoolCache cacheCartesianFixed_
 
edm::BoolCache cachePolarFixed_
 has cache been set? More...
 
float eta_
 
float mass_
 
LorentzVector p4Cartesian_
 internal cache for p4 More...
 
PolarLorentzVector p4Polar_
 internal cache for p4 More...
 
int pdgId_
 PDG identifier. More...
 
float phi_
 
float pt_
 four-momentum Lorentz vector More...
 
Charge qx3_
 electric charge More...
 
int status_
 status word More...
 
Point vertex_
 vertex position 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
Version
Id:
TriggerObjectStandAlone.h,v 1.12 2010/12/20 20:05:52 vadler Exp

Definition at line 32 of file TriggerObjectStandAlone.h.

Constructor & Destructor Documentation

pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( )
inline

Constructors and Destructor.

Default constructor

Definition at line 77 of file TriggerObjectStandAlone.h.

77 : TriggerObject() {};
TriggerObject()
Constructors and Destructor.
pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( const TriggerObject trigObj)
inline

Constructor from pat::TriggerObject.

Definition at line 79 of file TriggerObjectStandAlone.h.

79 : TriggerObject( trigObj ) {};
TriggerObject()
Constructors and Destructor.
pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( const trigger::TriggerObject trigObj)
inline

Constructor from trigger::TriggerObject.

Definition at line 81 of file TriggerObjectStandAlone.h.

81 : TriggerObject( trigObj ) {};
TriggerObject()
Constructors and Destructor.
pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::LeafCandidate leafCand)
inline

Constructor from reco::Candidate.

Definition at line 83 of file TriggerObjectStandAlone.h.

83 : TriggerObject( leafCand ) {};
TriggerObject()
Constructors and Destructor.
pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::Particle::LorentzVector vec,
int  id = 0 
)
inline

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

Definition at line 85 of file TriggerObjectStandAlone.h.

85 : TriggerObject( vec, id ) {};
TriggerObject()
Constructors and Destructor.
pat::TriggerObjectStandAlone::TriggerObjectStandAlone ( const reco::Particle::PolarLorentzVector vec,
int  id = 0 
)
inline

Definition at line 86 of file TriggerObjectStandAlone.h.

86 : TriggerObject( vec, id ) {};
TriggerObject()
Constructors and Destructor.
virtual pat::TriggerObjectStandAlone::~TriggerObjectStandAlone ( )
inlinevirtual

Destructor.

Definition at line 89 of file TriggerObjectStandAlone.h.

89 {};

Member Function Documentation

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

Adds a new L1 algorithm name.

Definition at line 100 of file TriggerObjectStandAlone.h.

References addPathOrAlgorithm().

100 { addPathOrAlgorithm( algorithmName, algoCondAccepted ); };
void addPathOrAlgorithm(const std::string &name, bool firing=true)
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 96 of file TriggerObjectStandAlone.h.

References addFilterOrCondition().

96 { 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 94 of file TriggerObjectStandAlone.h.

References addFilterOrCondition().

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

94 { 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 58 of file TriggerObjectStandAlone.h.

References filterLabels_, and hasFilterOrCondition().

Referenced by addConditionName(), and addFilterLabel().

58 { if ( ! hasFilterOrCondition( name ) ) filterLabels_.push_back( name ); };
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names od 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 
)
inline

Adds a new HLT path name.

Definition at line 98 of file TriggerObjectStandAlone.h.

References addPathOrAlgorithm().

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

98 { addPathOrAlgorithm( pathName, pathLastFilterAccepted ); };
const std::string * pathName() const
Definition: HLTadd.h:31
void addPathOrAlgorithm(const std::string &name, bool firing=true)
Adds a new HLT path or L1 algorithm name.
void TriggerObjectStandAlone::addPathOrAlgorithm ( const std::string &  name,
bool  firing = true 
)
private

Adds a new HLT path or L1 algorithm name.

Definition at line 70 of file TriggerObjectStandAlone.cc.

References hasPathOrAlgorithm(), pathLastFilterAccepted_, and pathNames_.

Referenced by addAlgorithmName(), and addPathName().

71 {
72  // Check, if path is already assigned
73  if ( ! hasPathOrAlgorithm( name, false ) ) {
74  // The path itself
75  pathNames_.push_back( name );
76  // The corresponding usage of the trigger objects
77  pathLastFilterAccepted_.push_back( firing );
78  }
79 }
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 firing=true) const
Checks, if a certain HLT path or L1 algorithm name is assigned.
std::vector< bool > pathLastFilterAccepted_
bool pat::TriggerObjectStandAlone::algo ( const std::string &  algorithmName,
unsigned  algoCondAccepted = 1 
) const
inline

Calls 'hasAlgorithmName(...)'.

Definition at line 137 of file TriggerObjectStandAlone.h.

References hasAlgorithmName().

137 { 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 108 of file TriggerObjectStandAlone.h.

References pathsOrAlgorithms().

108 { return pathsOrAlgorithms( algoCondAccepted ); };
std::vector< std::string > pathsOrAlgorithms(bool firing=true) const
Gets all HLT path or L1 algorithm names.
virtual bool pat::TriggerObjectStandAlone::coll ( const std::string &  collName) const
inlinevirtual

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

Reimplemented from pat::TriggerObject.

Definition at line 139 of file TriggerObjectStandAlone.h.

References hasCollection().

139 { 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 133 of file TriggerObjectStandAlone.h.

References hasConditionName().

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

Gets all L1 condition names.

Definition at line 104 of file TriggerObjectStandAlone.h.

References filtersOrConditions().

104 { return filtersOrConditions(); };
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 131 of file TriggerObjectStandAlone.h.

References hasFilterLabel().

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

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

Gets all HLT filter labels.

Definition at line 102 of file TriggerObjectStandAlone.h.

References filtersOrConditions().

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

Gets all HLT filter labels or L1 condition names.

Definition at line 62 of file TriggerObjectStandAlone.h.

References filterLabels_.

Referenced by conditionNames(), and filterLabels().

62 { return filterLabels_; };
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names od L1 conditions the trigger objects has been used in...
bool pat::TriggerObjectStandAlone::hasAlgoCondAccepted ( ) const
inline

Definition at line 124 of file TriggerObjectStandAlone.h.

References hasFiring().

124 { return hasFiring(); };
bool hasFiring() const
Checks, if the usage indicator vector has 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 118 of file TriggerObjectStandAlone.h.

References hasPathOrAlgorithm().

Referenced by algo().

118 { return hasPathOrAlgorithm( algorithmName, algoCondAccepted ); };
bool hasPathOrAlgorithm(const std::string &name, bool firing=true) 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 24 of file TriggerObjectStandAlone.cc.

References split, and wildcard_.

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

25 {
26  // Special cases first
27  // Always false for empty vector to check
28  if ( nameVec.empty() ) return false;
29  // Always true for general wild-card(s)
30  if ( name.find_first_not_of( wildcard_ ) == std::string::npos ) return true;
31  // Split name to evaluate in parts, seperated by wild-cards
32  std::vector< std::string > namePartsVec;
33  boost::split( namePartsVec, name, boost::is_any_of( std::string( 1, wildcard_ ) ), boost::token_compress_on );
34  // Iterate over vector of names to search
35  for ( std::vector< std::string >::const_iterator iVec = nameVec.begin(); iVec != nameVec.end(); ++iVec ) {
36  // Not failed yet
37  bool failed( false );
38  // Start searching at the first character
39  size_type index( 0 );
40  // Iterate over evaluation name parts
41  for ( std::vector< std::string >::const_iterator iName = namePartsVec.begin(); iName != namePartsVec.end(); ++iName ) {
42  // Empty parts due to
43  // - wild-card at beginning/end or
44  // - multiple wild-cards (should be supressed by 'boost::token_compress_on')
45  if ( iName->length() == 0 ) continue;
46  // Search from current index and
47  // set index to found occurence
48  index = iVec->find( *iName, index );
49  // Failed and exit loop, if
50  // - part not found
51  // - part at beginning not found there
52  if ( index == std::string::npos || ( iName == namePartsVec.begin() && index > 0 ) ) {
53  failed = true;
54  break;
55  }
56  // Increase index by length of found part
57  index += iName->length();
58  }
59  // Failed, if end of name not reached
60  if ( index < iVec->length() && namePartsVec.back().length() != 0 ) failed = true;
61  // Match found!
62  if ( ! failed ) return true;
63  }
64  // No match found!
65  return false;
66 }
size_t size_type
Definition: Candidate.h:32
static const char wildcard_
Constants.
unsigned int index
Definition: LeafCandidate.h:33
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 141 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 coll(), and pat::PATTriggerProducer::produce().

142 {
143  // Move to wild-card parser, if needed only
144  if ( collName.find( wildcard_ ) != std::string::npos ) {
145  // True, if collection name is simply fine
146  if ( hasAnyName( collName, std::vector< std::string >( 1, collection() ) ) ) return true;
147  // Check, if collection name possibly fits in an edm::InputTag approach
148  const edm::InputTag collectionTag( collection() );
149  const edm::InputTag collTag( collName );
150  // If evaluated collection tag contains a process name, it must have been found already by identity check
151  if ( collTag.process().empty() ) {
152  // Check instance ...
153  if ( ( collTag.instance().empty() && collectionTag.instance().empty() ) || hasAnyName( collTag.instance(), std::vector< std::string >( 1, collectionTag.instance() ) ) ) {
154  // ... and label
155  return hasAnyName( collTag.label(), std::vector< std::string >( 1, collectionTag.label() ) );
156  }
157  }
158  return false;
159  }
160  // Use parent class's method otherwise
161  return TriggerObject::hasCollection( collName );
162 }
static const char wildcard_
Constants.
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
virtual bool hasCollection(const std::string &collName) const
Checks, if a certain label of original collection is assigned.
std::string collection() const
Get the label of the collection the trigger object originates from.
Definition: TriggerObject.h:94
virtual bool pat::TriggerObjectStandAlone::hasCollection ( const edm::InputTag collName) const
inlinevirtual

Reimplemented from pat::TriggerObject.

Definition at line 121 of file TriggerObjectStandAlone.h.

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

Referenced by hasCollection().

121 { 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:72
bool pat::TriggerObjectStandAlone::hasConditionName ( const std::string &  conditionName) const
inline

Checks, if a certain L1 condition name is assigned.

Definition at line 114 of file TriggerObjectStandAlone.h.

References hasFilterOrCondition().

Referenced by cond().

114 { 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 112 of file TriggerObjectStandAlone.h.

References hasFilterOrCondition().

Referenced by filter().

112 { 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 99 of file TriggerObjectStandAlone.cc.

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

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

100 {
101  // Move to wild-card parser, if needed
102  if ( name.find( wildcard_ ) != std::string::npos ) return hasAnyName( name, filterLabels_ );
103  // Return, if filter label is assigned
104  return ( std::find( filterLabels_.begin(), filterLabels_.end(), name ) != filterLabels_.end() );
105 }
static const char wildcard_
Constants.
std::vector< std::string > filterLabels_
Vector of labels of all HLT filters or names od 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:7
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
bool pat::TriggerObjectStandAlone::hasFiring ( ) const
inlineprivate

Checks, if the usage indicator vector has been filled.

Definition at line 70 of file TriggerObjectStandAlone.h.

References pathLastFilterAccepted_, and pathNames_.

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

70 { 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::hasPathLastFilterAccepted ( ) const
inline

Checks, if the usage indicator vector has been filled.

Definition at line 123 of file TriggerObjectStandAlone.h.

References hasFiring().

123 { return hasFiring(); };
bool hasFiring() const
Checks, if the usage indicator vector has been filled.
bool pat::TriggerObjectStandAlone::hasPathName ( const std::string &  pathName,
bool  pathLastFilterAccepted = true 
) const
inline

Checks, if a certain HLT path name is assigned.

Definition at line 116 of file TriggerObjectStandAlone.h.

References hasPathOrAlgorithm().

Referenced by path().

116 { return hasPathOrAlgorithm( pathName, pathLastFilterAccepted ); };
const std::string * pathName() const
Definition: HLTadd.h:31
bool hasPathOrAlgorithm(const std::string &name, bool firing=true) const
Checks, if a certain HLT path or L1 algorithm name is assigned.
bool TriggerObjectStandAlone::hasPathOrAlgorithm ( const std::string &  name,
bool  firing = true 
) const
private

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

Definition at line 109 of file TriggerObjectStandAlone.cc.

References spr::find(), hasAnyName(), hasFiring(), match(), AlCaRecoCosmics_cfg::name, pathLastFilterAccepted_, pathNames_, pathsOrAlgorithms(), and wildcard_.

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

110 {
111  // Move to wild-card parser, if needed
112  if ( name.find( wildcard_ ) != std::string::npos ) return hasAnyName( name, pathsOrAlgorithms( firing ) );
113  // Deal with older PAT-tuples, where trigger object usage is not available
114  if ( ! hasFiring() ) firing = false;
115  // Check, if path name is assigned at all
116  std::vector< std::string >::const_iterator match( std::find( pathNames_.begin(), pathNames_.end(), name ) );
117  // False, if path name not assigned
118  if ( match == pathNames_.end() ) return false;
119  // Return for assigned path name, if trigger object usage meets requirement
120  return ( firing ? pathLastFilterAccepted_.at( match - pathNames_.begin() ) : true );
121 }
bool hasFiring() const
Checks, if the usage indicator vector has been filled.
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:7
bool hasAnyName(const std::string &name, const std::vector< std::string > &nameVec) const
Private methods.
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:6
std::vector< bool > pathLastFilterAccepted_
std::vector< std::string > pathsOrAlgorithms(bool firing=true) const
Gets all HLT path or L1 algorithm names.
bool pat::TriggerObjectStandAlone::path ( const std::string &  pathName,
unsigned  pathLastFilterAccepted = 1 
) const
inline

Calls 'hasPathName(...)'.

Definition at line 135 of file TriggerObjectStandAlone.h.

References hasPathName().

135 { return hasPathName( pathName, bool( pathLastFilterAccepted ) ); };
bool hasPathName(const std::string &pathName, bool pathLastFilterAccepted=true) const
Checks, if a certain HLT path name is assigned.
const std::string * pathName() const
Definition: HLTadd.h:31
std::vector< std::string > pat::TriggerObjectStandAlone::pathNames ( bool  pathLastFilterAccepted = true) const
inline

Gets all HLT path names.

Definition at line 106 of file TriggerObjectStandAlone.h.

References pathsOrAlgorithms().

106 { return pathsOrAlgorithms( pathLastFilterAccepted ); };
std::vector< std::string > pathsOrAlgorithms(bool firing=true) const
Gets all HLT path or L1 algorithm names.
std::vector< std::string > TriggerObjectStandAlone::pathsOrAlgorithms ( bool  firing = true) const
private

Gets all HLT path or L1 algorithm names.

Definition at line 83 of file TriggerObjectStandAlone.cc.

References hasFiring(), pathLastFilterAccepted_, and pathNames_.

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

84 {
85  // All path names, if usage not restricted (not required or not available)
86  if ( ! firing || ! hasFiring() ) return pathNames_;
87  // Temp vector of path names
88  std::vector< std::string > paths;
89  // Loop over usage vector and fill corresponding paths into temp vector
90  for ( unsigned iPath = 0; iPath < pathNames_.size(); ++iPath ) {
91  if ( pathLastFilterAccepted_.at( iPath ) ) paths.push_back( pathNames_.at( iPath ) );
92  }
93  // Return temp vector
94  return paths;
95 }
bool hasFiring() const
Checks, if the usage indicator vector has 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 > pathLastFilterAccepted_
TriggerObject TriggerObjectStandAlone::triggerObject ( )

Gets the pat::TriggerObject (parent class)

Definition at line 128 of file TriggerObjectStandAlone.cc.

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

129 {
130  // Create a TriggerObjects
131  TriggerObject theObj( p4(), pdgId() );
132  // Set its collection and trigger objects types (no c'tor for that)
133  theObj.setCollection( collection() );
134  for ( size_t i = 0; i < triggerObjectTypes().size(); ++i ) theObj.addTriggerObjectType( triggerObjectTypes().at( i ) );
135  // Return TriggerObject
136  return theObj;
137 }
int i
Definition: DBlmapReader.cc:9
virtual int pdgId() const
PDG identifier.
Analysis-level trigger object class.
Definition: TriggerObject.h:49
std::string collection() const
Get the label of the collection the trigger object originates from.
Definition: TriggerObject.h:94
std::vector< int > triggerObjectTypes() const
Get all trigger object type identifiers.
virtual const LorentzVector & p4() const
four-momentum Lorentz vector
list at
Definition: asciidump.py:428

Member Data Documentation

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

Vector of labels of all HLT filters or names od 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 addFilterOrCondition(), filtersOrConditions(), and hasFilterOrCondition().

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 in data.

Definition at line 46 of file TriggerObjectStandAlone.h.

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

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

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

const char TriggerObjectStandAlone::wildcard_ = '*'
staticprivate

Constants.

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

Definition at line 51 of file TriggerObjectStandAlone.h.

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