Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:20:29

0001 #ifndef L1Trigger_L1TGlobal_EnergySumZdcTemplate_h
0002 #define L1Trigger_L1TGlobal_EnergySumZdcTemplate_h
0003 
0004 /**
0005  * \class EnergySumZdcTemplate
0006  *
0007  *
0008  * Description: L1 Global Trigger energy-sum template.
0009  *
0010  * Implementation:
0011  *    <TODO: enter implementation details>
0012  *
0013  * \author: Vasile Mihai Ghete - HEPHY Vienna
0014  *
0015  * $Date$
0016  * $Revision$
0017  *
0018  */
0019 
0020 // system include files
0021 #include <string>
0022 #include <iosfwd>
0023 
0024 // user include files
0025 
0026 //   base class
0027 #include "L1Trigger/L1TGlobal/interface/GlobalCondition.h"
0028 
0029 // forward declarations
0030 
0031 // class declaration
0032 class EnergySumZdcTemplate : public GlobalCondition {
0033 public:
0034   // constructor
0035   EnergySumZdcTemplate();
0036 
0037   // constructor
0038   EnergySumZdcTemplate(const std::string&);
0039 
0040   // constructor
0041   EnergySumZdcTemplate(const std::string&, const l1t::GtConditionType&);
0042 
0043   // copy constructor
0044   EnergySumZdcTemplate(const EnergySumZdcTemplate&);
0045 
0046   // destructor
0047   ~EnergySumZdcTemplate() override;
0048 
0049   // assign operator
0050   EnergySumZdcTemplate& operator=(const EnergySumZdcTemplate&);
0051 
0052 public:
0053   struct ObjectParameter {
0054     unsigned int etLowThreshold;
0055     unsigned int etHighThreshold;
0056   };
0057 
0058 public:
0059   inline const std::vector<ObjectParameter>* objectParameter() const { return &m_objectParameter; }
0060 
0061   /// set functions
0062   void setConditionParameter(const std::vector<ObjectParameter>&);
0063 
0064   /// print the condition
0065   void print(std::ostream& myCout) const override;
0066 
0067   /// output stream operator
0068   friend std::ostream& operator<<(std::ostream&, const EnergySumZdcTemplate&);
0069 
0070 private:
0071   /// copy function for copy constructor and operator=
0072   void copy(const EnergySumZdcTemplate& cp);
0073 
0074 private:
0075   /// variables containing the parameters
0076   std::vector<ObjectParameter> m_objectParameter;
0077 };
0078 
0079 #endif