CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
L1GtJetCountsCondition Class Reference

#include <L1GtJetCountsCondition.h>

Inheritance diagram for L1GtJetCountsCondition:
L1GtConditionEvaluation

Public Member Functions

const bool evaluateCondition () const
 the core function to check if the condition matches More...
 
const L1GtJetCountsTemplategtJetCountsTemplate () const
 get / set the pointer to a L1GtCondition More...
 
const L1GlobalTriggerPSBgtPSB () const
 get / set the pointer to PSB More...
 
 L1GtJetCountsCondition ()
 
 L1GtJetCountsCondition (const L1GtCondition *, const L1GlobalTriggerPSB *, const int nrL1JetCounts)
 from base template condition (from event setup usually) More...
 
 L1GtJetCountsCondition (const L1GtJetCountsCondition &)
 
L1GtJetCountsConditionoperator= (const L1GtJetCountsCondition &)
 
void print (std::ostream &myCout) const
 print condition More...
 
void setGtJetCountsTemplate (const L1GtJetCountsTemplate *)
 
void setGtPSB (const L1GlobalTriggerPSB *)
 set the pointer to PSB More...
 
virtual ~L1GtJetCountsCondition ()
 
- Public Member Functions inherited from L1GtConditionEvaluation
bool condLastResult () const
 get the latest result for the condition More...
 
int condMaxNumberObjects () const
 
void evaluateConditionStoreResult ()
 call evaluateCondition and save last result More...
 
CombinationsInCond const & getCombinationsInCond () const
 get all the object combinations evaluated to true in the condition More...
 
virtual std::string getNumericExpression () const
 get numeric expression More...
 
 L1GtConditionEvaluation ()
 constructor More...
 
void setCondMaxNumberObjects (int condMaxNumberObjectsValue)
 
void setVerbosity (const int verbosity)
 
virtual ~L1GtConditionEvaluation ()
 destructor More...
 

Private Member Functions

void copy (const L1GtJetCountsCondition &cp)
 copy function for copy constructor and operator= More...
 

Private Attributes

const L1GtJetCountsTemplatem_gtJetCountsTemplate
 pointer to a L1GtJetCountsTemplate More...
 
const L1GlobalTriggerPSBm_gtPSB
 pointer to PSB, to be able to get the trigger objects More...
 
unsigned int m_numberL1JetCounts
 maximum number of jet counts More...
 

Additional Inherited Members

- Protected Member Functions inherited from L1GtConditionEvaluation
template<class Type1 >
const bool checkBit (const Type1 &mask, const unsigned int bitNumber) const
 check if a bit with a given number is set in a mask More...
 
template<class Type1 , class Type2 >
const bool checkThreshold (const Type1 &threshold, const Type2 &value, const bool condGEqValue) const
 
CombinationsInCondcombinationsInCond () const
 get all the object combinations (to fill it...) More...
 
- Protected Attributes inherited from L1GtConditionEvaluation
CombinationsInCond m_combinationsInCond
 store all the object combinations evaluated to true in the condition More...
 
bool m_condLastResult
 the last result of evaluateCondition() More...
 
int m_condMaxNumberObjects
 
int m_verbosity
 verbosity level More...
 

Detailed Description

Description: evaluation of a CondJetCounts condition.

Implementation: <TODO: enter implementation details>

Author
: Vasile Mihai Ghete - HEPHY Vienna

Definition at line 33 of file L1GtJetCountsCondition.h.

Constructor & Destructor Documentation

L1GtJetCountsCondition::L1GtJetCountsCondition ( )

constructors default

Definition at line 37 of file L1GtJetCountsCondition.cc.

37  :
39 
40  //empty
41 
42 }
L1GtJetCountsCondition::L1GtJetCountsCondition ( const L1GtCondition jcTemplate,
const L1GlobalTriggerPSB ptrPSB,
const int  nrL1JetCounts 
)

from base template condition (from event setup usually)

Definition at line 45 of file L1GtJetCountsCondition.cc.

References L1GtConditionEvaluation::m_condMaxNumberObjects.

46  :
48  m_gtJetCountsTemplate(static_cast<const L1GtJetCountsTemplate*>(jcTemplate)),
49  m_gtPSB(ptrPSB),
50  m_numberL1JetCounts(nrL1JetCounts)
51 {
52 
53  // maximum number of objects received for the evaluation of the condition
54  // no objects, in fact, just a number
56 
57 }
const L1GlobalTriggerPSB * m_gtPSB
pointer to PSB, to be able to get the trigger objects
unsigned int m_numberL1JetCounts
maximum number of jet counts
const L1GtJetCountsTemplate * m_gtJetCountsTemplate
pointer to a L1GtJetCountsTemplate
L1GtJetCountsCondition::L1GtJetCountsCondition ( const L1GtJetCountsCondition cp)

Definition at line 73 of file L1GtJetCountsCondition.cc.

References copy().

73  :
75 
76  copy(cp);
77 
78 }
void copy(const L1GtJetCountsCondition &cp)
copy function for copy constructor and operator=
L1GtJetCountsCondition::~L1GtJetCountsCondition ( )
virtual

Definition at line 81 of file L1GtJetCountsCondition.cc.

81  {
82 
83  // empty
84 
85 }

Member Function Documentation

void L1GtJetCountsCondition::copy ( const L1GtJetCountsCondition cp)
private

copy function for copy constructor and operator=

Definition at line 60 of file L1GtJetCountsCondition.cc.

References L1GtConditionEvaluation::condLastResult(), L1GtConditionEvaluation::condMaxNumberObjects(), L1GtConditionEvaluation::getCombinationsInCond(), gtJetCountsTemplate(), gtPSB(), L1GtConditionEvaluation::m_combinationsInCond, L1GtConditionEvaluation::m_condLastResult, L1GtConditionEvaluation::m_condMaxNumberObjects, m_gtJetCountsTemplate, m_gtPSB, and L1GtConditionEvaluation::m_verbosity.

Referenced by gtPSB(), L1GtJetCountsCondition(), and operator=().

60  {
61 
63  m_gtPSB = cp.gtPSB();
64 
68 
70 
71 }
bool m_condLastResult
the last result of evaluateCondition()
CombinationsInCond m_combinationsInCond
store all the object combinations evaluated to true in the condition
const L1GtJetCountsTemplate * gtJetCountsTemplate() const
get / set the pointer to a L1GtCondition
const L1GlobalTriggerPSB * m_gtPSB
pointer to PSB, to be able to get the trigger objects
const L1GlobalTriggerPSB * gtPSB() const
get / set the pointer to PSB
const L1GtJetCountsTemplate * m_gtJetCountsTemplate
pointer to a L1GtJetCountsTemplate
CombinationsInCond const & getCombinationsInCond() const
get all the object combinations evaluated to true in the condition
bool condLastResult() const
get the latest result for the condition
const bool L1GtJetCountsCondition::evaluateCondition ( ) const
virtual

the core function to check if the condition matches

Implements L1GtConditionEvaluation.

Definition at line 109 of file L1GtJetCountsCondition.cc.

References L1GtConditionEvaluation::checkThreshold(), hitfit::clear(), L1GtConditionEvaluation::combinationsInCond(), L1GtCondition::condGEq(), L1GctJetCounts::count(), L1GtJetCountsTemplate::ObjectParameter::countIndex, L1GtJetCountsTemplate::ObjectParameter::countThreshold, L1GlobalTriggerPSB::getCandL1JetCounts(), m_gtJetCountsTemplate, m_gtPSB, m_numberL1JetCounts, and L1GtJetCountsTemplate::objectParameter().

109  {
110 
111  // number of trigger objects in the condition
112  // in fact, there is only one object
113  int iCondition = 0;
114 
115  // condition result condResult will be set to true if the jet counts
116  // passes the requirement
117  bool condResult = false;
118 
119  // store the index of the JetCount object
120  // from the combination evaluated in the condition
121  SingleCombInCond objectsInComb;
122 
123  // clear the m_combinationsInCond vector
125 
126  // get the jet counts (event / condition)
127  const L1GctJetCounts* jetCounts = m_gtPSB->getCandL1JetCounts();
128 
129  // protection against missing jet counts collection
130  if (jetCounts == 0) {
131  return false;
132  }
133 
135  ( *(m_gtJetCountsTemplate->objectParameter()) )[iCondition];
136 
137  unsigned int cIndex = objPar.countIndex;
138 
139  if (cIndex >= m_numberL1JetCounts) {
140 
141  edm::LogError("L1GlobalTrigger") << "\nL1GtJetCountsCondition error: countIndex "
142  << cIndex << "greater than maximum allowed count = " << m_numberL1JetCounts
143  << "\n ==> condResult = false " << std::endl;
144  return false;
145 
146  }
147 
148  unsigned int countValue = jetCounts->count(cIndex);
149 
150  // check countThreshold
151  if ( !checkThreshold(objPar.countThreshold, countValue, m_gtJetCountsTemplate->condGEq()) ) {
152 
153  return false;
154  }
155 
156  // index is always zero, as they are global quantities (there is only one object)
157  int indexObj = 0;
158 
159  objectsInComb.push_back(indexObj);
160  (combinationsInCond()).push_back(objectsInComb);
161 
162  // if we get here all checks were successful for this combination
163  // set the general result for evaluateCondition to "true"
164 
165  condResult = true;
166  return condResult;
167 
168 }
const L1GlobalTriggerPSB * m_gtPSB
pointer to PSB, to be able to get the trigger objects
CombinationsInCond & combinationsInCond() const
get all the object combinations (to fill it...)
std::vector< int > SingleCombInCond
typedefs
typedef for a single object template
const std::vector< ObjectParameter > * objectParameter() const
void clear(CLHEP::HepGenMatrix &m)
Helper function: Reset all elements of a matrix to 0.
Definition: matutil.cc:167
const bool checkThreshold(const Type1 &threshold, const Type2 &value, const bool condGEqValue) const
unsigned int m_numberL1JetCounts
maximum number of jet counts
unsigned count(unsigned i) const
get count by index
const L1GtJetCountsTemplate * m_gtJetCountsTemplate
pointer to a L1GtJetCountsTemplate
const bool condGEq() const
get / set condition GEq flag
const L1GctJetCounts * getCandL1JetCounts() const
pointer to JetCounts data list
const L1GtJetCountsTemplate* L1GtJetCountsCondition::gtJetCountsTemplate ( ) const
inline

get / set the pointer to a L1GtCondition

Definition at line 65 of file L1GtJetCountsCondition.h.

References m_gtJetCountsTemplate, and setGtJetCountsTemplate().

Referenced by copy().

65  {
66  return m_gtJetCountsTemplate;
67  }
const L1GtJetCountsTemplate * m_gtJetCountsTemplate
pointer to a L1GtJetCountsTemplate
const L1GlobalTriggerPSB* L1GtJetCountsCondition::gtPSB ( ) const
inline

get / set the pointer to PSB

Definition at line 72 of file L1GtJetCountsCondition.h.

References copy(), SimDataFormats::CaloAnalysis::cp, m_gtPSB, and setGtPSB().

Referenced by copy().

72  {
73  return m_gtPSB;
74  }
const L1GlobalTriggerPSB * m_gtPSB
pointer to PSB, to be able to get the trigger objects
L1GtJetCountsCondition & L1GtJetCountsCondition::operator= ( const L1GtJetCountsCondition cp)

Definition at line 88 of file L1GtJetCountsCondition.cc.

References copy().

89 {
90  copy(cp);
91  return *this;
92 }
void copy(const L1GtJetCountsCondition &cp)
copy function for copy constructor and operator=
void L1GtJetCountsCondition::print ( std::ostream &  myCout) const
virtual

print condition

Reimplemented from L1GtConditionEvaluation.

Definition at line 170 of file L1GtJetCountsCondition.cc.

References m_gtJetCountsTemplate, L1GtJetCountsTemplate::print(), and L1GtConditionEvaluation::print().

Referenced by L1GlobalTriggerGTL::run().

170  {
171 
172  m_gtJetCountsTemplate->print(myCout);
174 
175 }
void print(std::ostream &myCout) const override
print the condition
const L1GtJetCountsTemplate * m_gtJetCountsTemplate
pointer to a L1GtJetCountsTemplate
virtual void print(std::ostream &myCout) const
print condition
void L1GtJetCountsCondition::setGtJetCountsTemplate ( const L1GtJetCountsTemplate jcTemplate)

Definition at line 95 of file L1GtJetCountsCondition.cc.

References m_gtJetCountsTemplate.

Referenced by gtJetCountsTemplate().

95  {
96 
97  m_gtJetCountsTemplate = jcTemplate;
98 
99 }
const L1GtJetCountsTemplate * m_gtJetCountsTemplate
pointer to a L1GtJetCountsTemplate
void L1GtJetCountsCondition::setGtPSB ( const L1GlobalTriggerPSB ptrPSB)

set the pointer to PSB

Definition at line 102 of file L1GtJetCountsCondition.cc.

References m_gtPSB.

Referenced by gtPSB().

102  {
103 
104  m_gtPSB = ptrPSB;
105 
106 }
const L1GlobalTriggerPSB * m_gtPSB
pointer to PSB, to be able to get the trigger objects

Member Data Documentation

const L1GtJetCountsTemplate* L1GtJetCountsCondition::m_gtJetCountsTemplate
private
const L1GlobalTriggerPSB* L1GtJetCountsCondition::m_gtPSB
private

pointer to PSB, to be able to get the trigger objects

Definition at line 89 of file L1GtJetCountsCondition.h.

Referenced by copy(), evaluateCondition(), gtPSB(), and setGtPSB().

unsigned int L1GtJetCountsCondition::m_numberL1JetCounts
private

maximum number of jet counts

Definition at line 92 of file L1GtJetCountsCondition.h.

Referenced by evaluateCondition().